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Starting XAMPP for Linux 1.8.0. 

XAMPP: Starting Apache with SSL (and PHP5). 
XAMPP: Starting MySQL.. 

XAMPP: Starting ProFTPD... 

XAMPP for Linux started. 
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ООООО00000000000000000000000 
http://www.apachefriends.org/en/faq-xampp-windows.html [| 
[Windows] ДОДХАМРР FAQ] 


ПОПОВОВОВОЕ"Й О $ ПОДООООООДОДООООО0ОкКОДОДОДОСОСОДО 
О00000000242000 


Welcome to the XAMPP 1.7.7 Setup 
Wizard 


“ba к= will guide you through the installation of XAMPP 


It is recommended that you close all other applications 
before starting Setup. This will make it possible to update 
relevant system files without having to reboot your 
computer. 


Click Next to continue. 
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ПОМехО0000000000000000000000000000000000000000 

ОО000СООООООООООХАМРРООО00000000000000000000000000 

ПООООДЕ ОМ ех00000000000000000000000001-3000 


| Installing 
Please wait while XAMPP 1.7.7 is being installed. 


Extract: unknown.gif 
Extract: unknown.png 
Extract: up.gif 
Extract: up.png 


Extract: uu.gif 
Extract: uu.png 
Extract: uuencoded. gif 


Extract: uuencoded.pna 
Extract: world1.aif 
Extract: worldi.png 





01-3 ХАМРРОДДОДОДОД 


ОДОО0О0О000000000000000006 пі15пООДОСОДОХАМРРОДООО 
ОД00000000000000пігої Рапе00000000000001-4000 





Setup was completed successfully. 





|| [2] XAMPP 177 win32 





Congratulations! The installation was successful! Start the ХАМРР Control Panel 
now? 


Nullsoft Install System v2.35 
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XAMPP Control РапеП000000000000000000000000 
АрасһермМуѕоОТОПО00001-5000000000000000000000000000 
ОО00000000000000000000000Сопќёго! Panell iib nb d t 


[Ене cos | 


к, 


| [2] ХАМРР Control Panel v3.0.11 
Modules 
Service Module PID(s) Рогі( 5) 
Apache 5436 80 
MySQL 3440 3306 
Filezilla 
Mercury 


Xx Tomcat 


| 9:14:48 AM [apache] Uninstall the service manually first 
9:14:48 AM [mysql] MySQL Service Detected With Wrong Path 
[mysql] Uninstall the service manually first 
[mysql] Possible problem detected! 
[mysql] Port 3306 in use by "mysqld.exe"! 
[main] starting Check-Timer 
[main] Control Panel Ready 
| [apache] Starting apache service... 
| 19:15:23 AM [apache] Status change detected: running 
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1-600 


| E] XAMPP 18.0 


| € С! | © localhost/xampp/index.php 
| 
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= | ХА М р р f Г WI n W English ; Deutsch / Francais ; Nederlands | 
ЧР ЧЫР | Polski / Italiano f Norwegian / Español; =Z / 


Portugués (Brasil); Е ЕЕ 


Welcome to XAMPP for Windows! 


Iwelcomel Congratulations: АНЕ 
Ке tuc You have successfully installed XAMPP on this system! 


Now you can start using Apache and Co. You should first try »Status« on the left navigation to 
make sure everything works fine. 


For OpenSSL support please use the test certificate with htt: 
Good luck, Kay Vogelgesang + Ка! ‘Oswald’ Seidler 





01-6 ХАМРРИППП 


ПОПОВОВОВОХАМРРОПИПООНОВОНАраспе ПРНРОМУ О ЦИП 
О000000000000000№р://Іосаіһћоѕ/хатрр О00000000000000 
ОООО000000000000012. 50000000000ХАМРРОДООООДООО0О00000 
0000000 


14 Мас OS ХХАМРР 


ПППИПИХАМРРПППИПИППИГПИИПППГГІМас OS X 1.40000000 
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http://www.apachefriends.org/en/xampp-mac.html ОПООООООО 


ОДОООО0000000000000000000001- 7000000 


__| XAMPP for Mac OS X 1.7.3 
Ж 2 items, 318.65 GB available 


XAMPP for Mac OS X 


Applications 
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ООООО000000ХАМРРООДОООАррії сабіопє ОДООДОДОДО00000 
ДОДООО/Арріісабоп5/ХАМРРОПОДООХАМРР Control РапеПППП 


0012-8000 


6 items, 94.17 СВ available 

re) Date Modified Size Kind 
Feb 27, 2010 2:00 PM Alias 
Feb 27, 2010 2:00 PM Alias 
Feb 27, 2010 2:00 PM ОК Alias 


Feb 27, 2010 2:00 PM Alias 
XAMPP Control Feb 27, 2010 2:00 PM -- Application 
> |] xamppfiles Feb 27, 2010 2:01 PM == Folder 
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ОДДмУуерб ОДОО0О0Д0000У/Уео 0000000 
http://localhost/xampp/index.php Г(ХАМРРППППППППППП 


[00001-90010 


ХАМРР for Mac OS X 1.7.3 


r Mac 


mr | Welcome to XAMPP for Mac OS X 1.7.3! 


Congratulations: 
You successfully installed XAMPP on this system! 


e left navigation to make sure everything works fine. 
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ОДОХАМРРОДОООООООО0ОООО0ОО0О000000000000000000000 
ОХАМРРОДООДОООД 


e ДІ іпих/(ОМІХООДООДОО00000000000 
й /opt/lampp/lampp security 
• [lWindowsl|[ il i IWebi | III I 
http://localhost/xampp/index.php 0000000000000 
еси у ПО $еси у Console[] 
e UMacQQUUUU00000000000000 


Я /Applications/XAMPP/xamppfiles/xampp security 
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° ПОООМУу5ОЮІ 
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ОООО000000000000000000000000000000000000МУу S OCT 
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2.1 MySQL 


ПППППППППППМУ5ОІГ Community Server 5.5.21[][]][]MySQL 
ОООО000000000000000/ Муь00000000000500000000050021П 
LET ООО00000000000000000000000000000000000000000000 
MySQL АВО000000000000000000000000 


О000000000000000000005.5.220П00000000000000000000 
http://dev.mysql.com/doc/refman/5.5/en/news-5-5-x.html ПП 


ООО0О0000000000000000000000000000000 


ООООО0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 


ООО0ОО000000000000000000000000000000000000000 
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MySQL АВО0000000000МУ5ОЦШООООООООООООООООООО 
[Sun Microsystems[][]]]MySQL АВП[Огас!еЦЦПЦПЦЦ5ип 
Місгобу5егп5)0000000000ОгасіедрОМу5О0С0О000000Му5ої 
Community ЕдїнйопПОООДООООДОООООО000000000000Му50Ш 
Web[][]http://www.mysql.com/ ОО0000000000000000Мас OS 
ХООО00000000їїпих/(ОМІХОДОВЕРМОДООООДОДОО0 


Linux[]Mac OS хопоопоомузоштопоопоопоопомузониоопоооооооооопоо 
О00000000000 | 


ПОООДО0000000ОМУБОЇ 5.5.x Community Ѕегмег 00500 
UUUUUUhttp://dev.mysql.com/downloads/mysaql/5.5.htm! ПП! 


БЕНЕНЕЕЕЕЕЕЕЕЕЕЕЕЕШЕЕЕЕШЕЕЕЕЕЕ 
2.3 []Linux/UNIX[|]|iMySQL 
ППППППВРМППППППППППЫпих/ОМІХПППМУБОЦППППППППП 


ООКРМОДОМУу5ОЇ АВОДОООДОДЕРМОДОДОДОСОДОДОДООООЗАОО 
eA4[][]1x86[]H][]SuSE ПпчихПЦПЦИпихП 


ОПОЕРМОДООДООДООДОДОДОДОООД 
http://dev.mysql.com/downloads/mysql/5.5.html ПОООООООВО 
ЗОДО000000000 


е MySQL-server-type - VERSIONNUMBER .PLATFORM 
ерт —The MySQL server 

е MySQL-client-type - VERS/ONNUMBER .PLATFORM 
‚грит —The standard MySQL client libraries 


ОООДО0АРМОДОООО00000000 


Я rpm -i MySQL-server-VERSION.1386.rpm MySQL-client-VERSION.1386.rpm 


ПОООО0МЕКУІОММОМВЕАОООООООООО000000РРАТРОВМООООО000000000000 | 
ПОПОБОПОН"чхОООМУ$ОЕ 5.0 Server КРМОООМУ5О! -зегмег- standard-5.0.51a- - 


0.51е510. І586.грпа ПППППВЕРМППМУ5ОІ-сПепі- standard-5.0.51a-0.sles10.i586. | 
rpm[] x 


ППребіапо000000000 
http://dev.mysq!.com/downloads/mysql/5.5.html ПООООПУ“. deb 
ПООДОООДО0Д00000000000000000000000 


# dpkg -i mysql-VERSION-debiano.0-1686.deb 


ООО000000000000000000000000000000000009чпаірПќаг 
ООО0О0000000000000000000000000000000000000000000000 
ООО00000000000000000000 


й groupadd mysql 

4 useradd -r -g mysql mysql 

# cd /usr/local 

Я tar zxvf /path/to/mysql-VERSION-PLATFORM.tar.gz 


ПОО000УЕВК5ІОМ-РЕАТҒРОКМООО0000000000000000МУ50ОЕ 5.500 НЧичх0 0000 | 
ППППтувд|-5.5.21-1- |іпих2.6.1386.агр | 


ППОБЕВЕНЕВОВОВВЕНОВОВОЕ 
# In -5 mysql-VERSION-PLATFORM mysql 
# cd mysql 
ОООООВЕАОМЕДОДІМ ТАД ПОООООООООО МУ О ЦОООООООЦ 
ООО000000000000000 


й scripts/mysql install db --user-mysql 
Я chown -R root . 

# chown -R mysql mysql data 

й chgrp -R mysql . 

Я bin/mysqld safe --user=mysql & 


ООООО0О0000МУ5ОС0000000002.. 77000000" О0000000000 
ОО000000000000000002.6" 0000007000 


2.4 |Мас OS XI J[iIMySQL 


Mac OS ХООМУЗО ЦДООООООООМУуЗ ОЕ АВ0000000Мас OS 
ХО00000000000 
http://dev.mysql.com/downloads/mysqgl/5.5.html ПМУБОЦТП) 


ПППИПМас OS ХОДОДОДООООООО000000000000000000000000 


рОМОПППИППИПМас OS X 10.5010.6000032006400000000000 
ОПОР МерДОДОО ОВ МерПО0000000000000000000002-1000 


| | mysgl-5.5.21-0sx10.6-x86 64 
4 items, 3 MB available 


MySQLStartupltem. pkg ReadMe. txt 





02-100Му5О1 ОМеПОДОДО 
ОО00000000000000*.ркероб00000000000000 


10МузоРо000000002-2000000С0пііпчерро0р000 


ws Install MySQL 5.5.21-community for Mac OS X 


You will be guided through the steps necessary to 
install this software. 


ранне. 
| Continue 





012-2 МасПМу5ОШ ИШ ИШИП 


2 000000000000000О00Омузоц 000000000000000000000 
[Continue [II JII III) 


З000000000000000000000000000000 2-3000000000000О 
ДО0000Сопбпиеро) 


w Install MySQL 5.5.21-community for Мас OS X 


Select a Destination 


с Select the disk where you want to install ће MySQL 
Ө Introduction à 5.5.21-community for Mac OS X software. 





O Read Me 


Кара ҮРП 

(CCS NE 

© License 7 ig LAST 
D c 
E 


Mothership 
95.1 СВ free 
319.73 GB total 





5 ӨТІПТІ, 
4 зна | |” B. | U.C CERERE 
үн ae A 5 Installing this software requires 480.6 MB of space. 


( - GoBack , Back 3 С , Continue | | 





02-3 ПШПШ 


АОДО00О0000000000000001 nsta ПОДООООДООО0000000000000 
ОООО00000000000000000000000000000000000000002-2000 


Ө Introduction "5 | 
Bo. th, | 
zl 


© Read Me 
Ө License & JY) 
© Destination Select ' | 


The installation was successful. 


а Summ The software was installed. 
ИЕ 





[2-4 Музош по 


ПОООООООМУЗОЕ Startup Іёет0000000МУу5О 000000 
ПООООВОООООООООМУ ОЕ startup ІеепАДОООООО0000000000000 
00*.ркеро0000000000000000000000000Муѕог Startup Кет 
ОООО00О00000000000000Му 5010 


# sudo /Library/StartupItems/MySQLCOM/MySQLCOM start 


ОООО00Му ОС ОО0000000000000000000МУу 50200000 
Сегі+ ОПО000000000Му50:О00000002.7 "ВО00000” 000000000 
О00000000002.6"0000007000 


2.5 ПМЛлпдаом5 ПОДМУ5ОЇ 


МЛпаом (ПМУЗОСОДОДОДОДОООМісгової \/Лпао\у/$ЦЦЦП 
[Microsoft Windows Installer JMSIQQ0000 Windows ХРП 
Windows Server 2003[]Windows Vista[|]Windows 7[][][|MySQL 
ОО0000000000 
http://dev.mysql.com/downloads/mysql/5.0.html ПМуБОЦТИП 
UUUUUUUUU“Windows Downloads” IILI IWindows Essentials 
ОО000000". газ О0000000000000000000 


ППППППППППМУ50І1. AB[]I Windows Еззеп а! |ПППП 
Windows[J[J]My SQL 5.0.2000000000Млтаом 0 00000000000О 
IL 


Мпаом ПДОДОДОСІР Archive UUUUUUUUUZIP Агесрімеррдрдо00000 


http://dev.mysql.com/doc/refman/5.5/en/windows-choosing-package.html [| 


МУу5ОРПОДОДОДОД 


ОО00000000000000000 


1000". пп5ІООДОДОО00000000000000000002-500000Мехі 
00000 


981 MySQL Server 5.5 Setup 


Welcome to the MySQL Server 5.5 Setup 
Wizard 


Г | The Setup Wizard will install MySQL Server 5.5 on your 


computer. Click Next to continue or Cancel to exit the Setup 
Wizard. 


Copyright (c) 2000, 2011, Oracle and/or its affiliates. All 
rights reserved. 





П2-5 Млпаоуу5ПМу5ОШШЦПППШППП 


2LIDODUDCUC Ty риса ПО Cempleten in custemr p III 
2-60000Си5сопОООООДОДО0О0О00МУЗ5О0000Соптріеєедр 000 
МУу5ОСПООООООООО0О000000Турісаї ПП ПВ 
ПМУБОЦТТПППИПИПИИПИПИПИПППГПГІ Ту рісаїрророр000Мехі0 
ULL] 


MySQL Server 5.5 Setup 


Choose Setup Type 
Choose the setup type that best suits your needs 


Installs the most common program features. Recommended for most users. 


Allows users to choose which program features will be installed and where 
they will be installed. Recommended for advanced users. 


All program features will be installed. Requires the most disk space. 





02-6 — 00000000 
ЗООООД00000000000001п15са ПООООООО0ООДО0000000000000 


4NUUUUUUUUUUUUUUUMYSQL Configuration Wizard[]MySQL 
ООООДОО0000000000000000000000п7лу. і піДОДОСО000000000000 
О00Д2Му5О000000000Сопйадйге the MySQL Server Мом ПОП 
ПОРІпі6п0000002-7000 


jf) MySQL Server 5.5 Setup 


Completed the MySQL Server 5.5 Setup 
Wizard 


„ WM Click the Finish button to exit the Setup Wizard. 


Finish || 





02-7 ППОМУЗОЕПИПОООООООМУ$ОЕ Config uration Wizard 


Зб00000000000000000Мех (орородродродродорроророооо 
ЦИЦПЦЦОеїанеаЦП5їТапдадагаЦПЦПЦЦЦО_еїанНеа Configuration ДОД 
ПООО0000000000005апаага Configuration 000000000 
my.inilUUUUUUUUUUUDetailed СопйдиганопддддородоМехі 0 
ПП 


60000002-80000000000000000000000000000000000 
Developer МасһіпеГбегуег Machine[j[]Dedicated MySQL 
server МаспіперПрДДОДООДО0000000000000000000000000000 
ПО000000МУ50:0000ехеіорег МасріпеПОДООМу5ОЄ0О0000 
ООООО0000000000000000000Муз6є0000000000000005егмег 


МаспіпеДрДОДОМУЗОВ00О000000000000000000000000000 
Dedicated MySQL Server MachineQQ0000000000NextQO000 


MySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration 
Configure the MySQL Server 5,5 server instance. 


Please select a server type. This will influence memory, disk and CPU usage. 


r1 = This is a development machine, and many other applications will 
7 berun on it. MySQL Server should only use a minimal amount of 
| тетогу, 


[^ Server Machine 
г Several server applications will be running on this machine. 
— 4 Choose this option for web/application servers. MySQL will have 
| medium memory usage. 
[^ Dedicated MySQL Server Machine 
: Ей This machine is dedicated То run the MySQL Database Server. Ма 


1 other servers, such as a web or mail server, will be run. MySQL 
will utilize up to all available memory. 





02-8  DHIDEIDUDUUMy SQU TETIEIDUI 


7)дободобобобобобородбо оМиТНТтипсбіопаї! Database] 
Transactional Database[]Non-Iransactional Database Only[][] 
[Multifunctional Database[]lnnoDB[]MyISAM[]ULILEIEIEIEIEIETEETETETE 
По Тапзасопа! Database[][][]BnnnoDB[]MyISAM[[LILILILILILILI 
LUddiinnoeDB[]Non-Transactional Database Опудори ппорвц 
ПОООСООООООМУІЅ$АМДООО0000000000000000000000000 
Multifunctional Оаёќараѕе0000\ехіЦ000 


З ОДОООДОО0000000000000001п9 n e D вОДороррО0О0000000 
Ооброр00000000000002-90000000Мех о ОрООД0000000000000 


О000000000Ммехе IL IILI IILI IL I III! 


MySQL Server Instance Configuration Wizard 


MySQL Instance Configuration 


Configure the MySQL Server 5,5 server instance. 


Please select the drive for the InnoDB datafile, if you do not want to use the default 
settings. 
InnoDB Tablespace Settings 


— Please choose the drive and directory where the InnoDB 
| tablespace should be placed. 


с ¥ | Installation Path 


Drive Info 
Volume Name: 
File System: NTFS 


50 GB Diskspace Used [ | 521,4 GB Free Diskspace 


ex» | Cancel | 





02-9 Діппоб ВОДОДОДОДОДОО 


ОДООО0000000МузОРЛОДобобродордоррроруевороодордроб 
ПОО00000000000000000есіѕіоп Support (О055)/(О(АРППОІ00П 
ПППППППППП2 ОППОпйпе Transaction Processing (OLTP)LULDLDLL 


000000500)000Мапчатрророороророророоророророородоцо 
О000000мехе 0000 


10000000000003еїмогкіпо Оріїоп5 О000000000000000 
ТСРИРОДОДООООООДОМу5ОСПОД000003306ПДО000000000000 
ПОДОДО00000000000000000000000000000000000000000000 
[]|http://dev.mysqal.com/doc/refman/5.5/en/server-sg|l- 
mode.htmil ДОДОДО00000000000Мех 0000 


ll[]Networking Options[][][]L]pl]Character Ѕе 10000000 
Standard Character Ѕе 1Ц[ПЦПИЦИЦИЦПИЦГ а" HEEL] Best 
Support for Multilingualism"[]HLLILIL]U ТЕЗООООДОДУТЕЗОДОООП 
ОООООДО00000000000000000000000007 Manual Selected 
Default Character 5е."ОДОДО00000000000000000000000000 
ПМех 0 


12ППППМУ5ОШПППППППППП“!п5їа!! as Windows 
Service” UIUUUUUUUUUUUUUU“Launch the MySQL Server 
Automatically” UUUUUUUUUUUUUUMyYSQL БІПППППГУУІП аоуу5 
РАТНОДОДОДОДОДОООООООМУЗООООООООООДОДОДОДОДООДОДО 
00000000Мех (00000 


13[]Security Оріїоп5П0000000000000000000002-100000 
б00000000000ОгооєПОДОООДОО000 00000000" “Enable Root 
Access From Remote Маспіпе5"ПДДДОДОДОДОДОДОДОДОгоої) 
ООООДО00000000000000000000000000000000000000000000 
000000000000Мехі 0000 


MySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration 


Configure the MySQL Server 5.5 server instance. 


Please set the security options. 


м. Modify Security Settings 


2 New root password: НН Enter the root password. 
кк. Confirm: | | 


[ Enable root access from remote machines 


[ Create An Anonymous Account 


This option will create an anonymous account on this server. 
Please nate that this can lead to an insecure system. 


сва | [Weds] ома | 





02-10 ЏОМмузо ППОгоо 00000 


1400О00000000000000000Е2хесисеррроОО000000000000 
000000000000002-1100000000000000000000000Му5080000 
ОДОО0РІПпІ5ВОО00000 


MySQL Server Instance Configuration Wizard 
MySQL Server Instance Configuration 


Configure the MySQL Server 5,5 server instance. 


Processing configuration ... 


(wj Prepare configuration 

(vj Write configuration file (C:\Program Files Му Му SQL Server 5,5 ту im) 
(м?) Start service 

(vj Apply security settings 


Confi jon file created. 
Windows service MySQL installed 


Press [Finish] to close the Wizard. 





02-11 Му5ОШШЦППШПШПШП 


ОООДООО00000000000МУ5О0ООО0ООСРгодгат 
Files\MySQL\ MySQL Server 5.5\Q0000000000my.iniQo0 


ПОМу5ОЄ0000000002. "О000000000000000102.6П0 


2.6 00000 


ОООМу 50 ЄОООДОДО00000000000МУу5ОЧ00000А000Д0 
http://dev.mysql.com/doc/refman/5.5/en/problems.html [| 


ОО000000000000 


e ЏОпих/ ОМІХОМас OS ХОДОООООДООООДООМу 50000000 
ООООбО0000000000000000000000000000000 

• П00000МУЅОЦООО0000Ассеѕѕ аепіеа 000000000000 
ПОД 

• [|[(|[(|[[[||[||Сап'ї connect to бегуег ППМУБОВЦИПИПИІ 


ООДОО0Му ОС ООООПАООООДООООООООО0ОМУ5ОС0000000 
hnttp://lists.mysql.com/ ОПООО000000000000000Муѕ5ог АВООП 
0000 


2.7 00000 


ППППУМІПаомПИ іпих/ОМІХОДМас OS ХПООПМУБОЦОПОООЦ 
ОДОДО0000001 псегпеєдрОДООО00000000000000000000000 
Іпсегпе ПОДОДОМу 50 ЄПООООО00О0000000000000000го05000000 
ООООО0000000000001/ п:егпеєдро0ОО0000000000000000000000 
ООО0000000000000000 


2.7.1 [MYSQL 


ПОМу5ОЗ0ОО0000000000000000000000000000000000000 
ОООДО00000000000000000000001/п:егпеєдррр000000 


О0Муѕ5О Пипих/ ОМІХОМас OS ХПППШШШШШШШШМУ5ОШ 
ОД00000000000мго020600000000000г08:0000000000птузаї б 


даќараѕерОО0000000000000000000000 


ПОПИМУЗОЕОИНОО го ПНОПИОНОНИОЕ я егле ПП 00000 
ОООО000000000000000000г0060000МУуЗОЗООО00О00000000000 
00000 


# mysqld --и5ег-лоп root user пате 


ОД0000000000птуза E ID My ОВО 0О00000 


# mysqld --user=mysql 


ОООДОМу 5ОС:0О000000Му50:000біп)000Опузаіа safer ОД 
00000 


# bin/mysqld safe --user-mysql & 


2.7.2 ППМуУ5ОКПТІПО 


ППППППППИППИППМУБОЦТППИППИПМУБОНППППИПИПИППГПІ 
ПППИПППМУБОВППППИПИИПИИППППИППИПИППИПИПППППИПИППГІ 
ОО00000000 


ППМУБОЦТППИПИПИИППППППГППМУБОЦТППИМУ>ОІ. GUITTET | 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 


ППМУ-БОТПППИПИППИППИПИППИИППИПППППППИППГТПГТГІ 
Іпсегпе000000000000000000000000000000000000000000 
ОООО0000000000000Му SQ СОООООДО000000000000000000000 


ООО000000000000000000000000105есиге Shelli i ISSHI[II! 
ОООМУу5ОР0О055НОДОДООООДОО0О000000000000000000000000 
ОД000У/евбоброОООДОРАиРМулат п ООП 
http://www.phpmyadmin.net/ ПДОДОДОДОДОрПпрмудлатіподі 
ОДОО000ХАМРРОООООДДООООО000О000000іпеегпеєдбоборор000000 
ОДООО0000000Н T ГРООООООООО 


ООООО0О000000МУуЗОС0ОДОООО00О000000000000000000 


2.8 MySQL 


МУуЗОНПОООООО0О0ОО000000000МУЗОООО0000000000000 
ООДОМУуЗО С0ОДОДОЗОД0ОП 


° ПОООДО00000000 
• ПП 
° ПООООО000000000 


О0000000000000ппузаї ООООООО0МУЗОС0ДОДООО000000 
Lmysq  ОДОДОДООО000000000 


° columns priv - - ОО id ub dad 
° db ---- n icd 


° host —— -ОД ОО00О00000000000000 

° ргос5 priv - ---ОООО00000000 

° tables priv - - ОДОО0О0000000000000 
° user ----О ПП 


ООДОД0000Му5ОС0ООО0О00000000000000000000000000000 
ООО0000000000000000000000000000 


2.8.1 [JD 


ОООО0000000000000МУуЗОС0ОЗООООООЗОО0ОО00000000000 
ПП 


10МУу5ОРПООООООО00000000000000000000000000000000 
ООООО0О00000000000000000000000МУ5ОС0000000 


2 ОООО0000000005О0:000МУу5ОС:0ОД0000000000000000000 
О0001000000000000000000000000200000000000000оеро00 
ОДабс123000МУу5ОС00000000000поу ВОДООООООООО00000000 
ОООО00000000000000000000000000 


e (ILL 

° QUWoe 000 

е |ПоеПП оса лозЦ ПП 

• (Ојоебб оса лоз ПОООООО тур ВОООЦ 


ОО0000000000000 


й mysql -h localhost -u joe -pabci23 test 
Error 1045: Access denied for user: 'joe&localhost' (Using password: YES) 


ПППППаврс1і2З ТПоеПППосаіһов ПО my DBE]EEH My SOLE] 
бр0000000000000)2ебдор000000000000Д)о0У 000000000000 
000000000000000000 


й mysql -h localhost -u joe -pabc123 test 

Reading table information for completion of table and column names 
You can turn off this feature to get a quicker startup with -A 
Welcome to the MySQL monitor. Commands end with ; ог 194. 

Your MySQL connection id is 12 to server version: 5.5.21-log 
Type 'help;' or "Аһ" for help. Type "Ас! to clear the buffer. 
mysql> SELECT * FROM test table; 

довів et ен еден + 

| id | test_field | 

Ғы нов ETE ~ 

| 1 | blah | 

| 2 | blah blah | 

+----+------------ + 


2 rows in set (0.0 sec) 


mysql> INSERT INTO test table VALUES ('', ‘my text '); 
Error 1044: Access denied for user: 'joeelocalhost' (Using password: YES) 


ОООО0000000000000000000000000000000000000000000 


ОООО000000000000005ЕСЕСТОПОООООДОООООО000000ІМУ5ЕВТО 
ОЕСЕТЕДООО 


ООДОО000000000іпеегпеєООО000Му5ОЗО00000000000000 
ООООО000000000000000000000000000000000000000000000 
ОООО000000000000000000000000000000 


ОООДО0000000000000001/п5егпеєд ро ООО000000000000 
О ОООО ОНОО ООНУНОНИ 


2.8.2 (ULL 


ООООО0000000000000000000000000000000000000000000 
ОООО0000000000000МУуЗО С0ОООО0О0000000000000МУ5ОЮОП 
ОО00000000000000000 


ООООО000000000006 КАМ ТОООО “о TETEIEIDM y SQ LOOO 
О00000000000000000000001ҸЕАТО000туѕа00000000000 
ОООО00000000000000000000000006КАМТООООО0006КАМТЦП 
ПООООЗКАМТОООООООООО 


GRANT privileges 
ОМ databasename,tablename 
TO usernameghost 
IDENTIFIED BY "password"; 


ООООДО000000000000000000000000000000 
http://dev.mysgl.com/doc/refman/5.5/en/grant.html []MySQL 


ПППОВАМТППП 


ALL ——00000000000 

ALTER ——10000000000000000 

CREATE — 000000000000 

DELETE — 000000000000 

DROP —— [1000100000000 

FILE ——00000000000000000000000000 

INDEX —— [1000000000000 

INSERT — — [0000000006000 

PROCESS ----ПООООООООДОДООООООДО00000000000 


° RELOAD ——|[ [LL ILIFLUSHIII IILI II III III! 

° SELECT —— 0100000000008 

° SHUTDOWN ----ПДООПОМУЗОООООООДООО00000000000 
° UPDATE ----ОООООО0О00000000 


О000000000000099һјс'5р0000оһп0000турвро000000 
ОПО 5ЕСЕСТОІМ5ЕВТОПОООООООООООООО0О000000000000000 


GRANT SELECT, INSERT 

ON myDB.* 

TO jonn@"%" 

IDENTIFIED BY '"99hjc!5"; 


ООО0000Р07е00000000000000000000000РООО000000000 
01% ООО0000000000000000000000000000 


ОД00006 ВАМТОДООД0О0О000000000000000000455а911000 
лапе ПП туСогтрапуППИПППИ Петтрюуее$ ППОДДАЄН 0000 
ОО000000000000000 


GRANT ALL 

ON myCompany.employees 

TO jane@janescomputer. company.com 
IDENTIFIED BY "4554911"; 


0000 LJjenescomputer.company.com[]LHEIP[]L]6e3.124.45.2[] 
ПООДООДООДО00000000000000000 


GRANT ALL 

ОМ myCompany.employees 

TO jane&ajanescomputer.company.com 
IDENTIFIED BY "4554911"; 


ОООО00000000000000000000000000000000 


ПОИСКАМ ТОООООООООО00000О000000000000000Му SQET TET 
HUUUUUFLUSH РЕАІМІСЕСЕЗОДОДОДОООООП 


2.8.3 (ULL 


ООООО0О0000000000000КЕМОКЕОООООДОО6ВАМТОДО 
ВЕМОКЕДОДООООО 


REVOKE privileges 
ОМ databasename.tablename 
FROM usernameiehostnarie ; 


ООДОО00001М5ЕВ ТООООООООООО0О0О00000рЕСЕТЕООО 
mysql ОДОДОООО0О0О0О000О000000000000000000000000 
ВЕМОКЕДООООООООП 


Д0000)о0бп0пуСопорапуд ОО0ДІМ5ЕВ ТОВООООДОДОДОП 
ВЕМОКЕДОГ 


REVOKE INSERE 
ON myCompany.* 
FROM јоћпаћоз пате 


ОООО000000000000000000000000000000000Му 5080000 
ППШҒЦУӘН РКІМПЕСЕӘТІП 


2.9 OU 


[| Windows[]Mac OS ХОДПОМу5О СОООООДООООДО000000000 
ПППИпих/ОМІХППППИПИПИППППИПИПИППППИПИПИППППМУБОЦТІ 


ПООООДО000000000Ціпих/ОМІХПООООООВРМОПООМУЗОЇГ 


ОДООООО000000000000000000000Му 5ОС0О0000000000000 
ОООО000000000000000000000 


МУуЗО800000000Огоо8 ООО0О000Му5ОЄ0О000000000000 
ООО000000000000000000 


ООООД0000Му SQ СПО ОООО000000000000000000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
0000000 


ОДОД Є RAN ТООООООД0ОО0000000000000плузаї ро Eu s err TE] 
ООДПОВЕМОКЕДООООООООО0О0000000 


2.10 Q&A 


ОПОООООООООПОКЕМОКЕЦОООООООЦО 


АОДОДОД00000000000000плузаї 00 ч5егОООООООПРЕТЕТЕ 
OOL 


ОПО000000птёегпеє00000МуѕоПгооє 00000 
00000000 


АДООО псегпеб рр О00000001п2егпеє ро ООО00000000000000 
УДО00ОгооєбООО00000000000000000000000000000000000 


52.950000000000000000 00000 го ШИШИШИ 


2.11 [I 


ОООООД00000000000000000000000000000000000000 


ЦЕН 


10000000000000000Му5ОЦОО00055Н0000000000 
2 ОДОМу5ОРПООООДО000000МУ5ОС000300000 


ЗОО оса поз ООП ОООООВ Н2ОВООООООООБЕЕСТЦ 
ІМ5ЕЕТООРБАТЕПООООООООООО ООООДО00000000000000000 
ПП 


ИЦ 


100055Н00000000000000000000000000000 
2 П0000000000000000000600 


3D] 


GRANT SELECT, INSERT, UPDATE 
ON BillDB.* 
ТО billelocalhost; 


ОО000000000000 


ӨШ 


О О О О О О О 
ULL] 


2 ПОДОМу SQLDIETTBOIDBIEIDUIEIEIG RAN ТООООДООООДО00000000 
ООО00000000000000 


ЗИООДВЕМОКЕЛОДООДОДФеОООО0О000000000 


ПЗП ППППАрасһе 


00000000 


° ПППАрасће 0 
° ПППАрасће 0100 
° Apache 000000000000 


ППИПППППППАрасһе УУ-БДОООООДОДООООО000000000 


3.1 Apache ULL 


UUUUUUhNttp ://httpd.apache.org ПАрасһе НТТРОПООООООО 
ППППАрасһе 2.0.x[JApache 2.2.x[]JApache 2.4.ХИИООПОООООООО 
ПОСОООО00Араспће 2.0.хЦПШШШШШШЦШШЦПАрасһе[ПШПП 
[Apache Software ГочпааНопй ПППОПИЗООПОООПАрасве 
2.4.ХПООДОО000000000000000000000000000000000000000 
ППППППАрасһе 2.2.хППАрасће 2.0. ХПДОДОДОРНРОМУ5ЗОЩОДО 
ПООООДО0О000000000000000000000000000П0ДАрастпе 2.0.х0 
ОООООАраспе 2.2.х0000000ДАраспе 2.4.x[ ООДОО0000000000 
ОДОАраспе 2.4.х00Д0О000000000000000000002распе 2.2.х0Ц 
ООООДО000000000000Араспе НТТРОДОПО2.4.1000000000000 
ООО0000000000 


АрасһеППП ПАрасһе Software Ғонпаачоп ПП ПППП 
ПООДОО0Д00Д00000000000000000000000000000000000000 
Араспер)0000000000000000000000000 


ООООД00000000000000000002.4.10000000000000000000 
Попов бр //ћЕра.арасће.ога/домтоаа. са! ПППППППППППППП 
ПОДОДОДОД0О0О00000000000000000000 


ООО0ОО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОО0О00000000000000000000000000000000000000000 


3.2 ПШПШ 


ОДОООО0000000000000000АрасперодобороорОбАраспеп 
ООООО000000000000000000000000000000000000000000000 
АрасһерО00000000000МІХОП0000000Арасһепо000000 
Шпихо0000000000000000000000000000000000пих/омхО00 
ООООО00000000000АрасперродооОМ/ пасом ПОООДАрасперо 0 
ОО0000000000000 


3.2.1 [DUE 


ООООО0000000000000000000000000000000000000000000 
ОО000000000000000Араспероб0000000000000000000000000 
ОО0000000000000000000000000000000Арасһероо00000000 
ООО0000000000000000000000000 


3.2.2 ОППОД0О000000 


Шпих/ОМІіХОООВОВОВОООООО000000Арасћерооо00000000 
ОДОД0О0000000000000000000000000000000000Арасперо 0 
ОО0000000000000000000000000000000000Арасһеп0000 
АрасперрдроОДМУ паом'вООДОООДО000, Wim d ew i LI III III! 
Linux/UNIXDIDIDDILILILILI 


3.3 [(jLinux/UNIX[] Apache 


ПППППППППИпих/ОМІХПППАрасһе 2.4.10Д00000000000000 
Араспеппппипиг 


1000000 

20000000 

ЗОДОД000000 

ООООДО0000000000 
3.3.1 [j]Apache[J[j] 


LULA pacher[]hltLphttp://httpd.apache.org/download.cgi [] 
ПОСОО0Арасһеоооо00000000000000000000000000ағо00000 
100921р00000сотргеѕ$П0000000000000000000009чп21іро00 
ОО0000" аг.02000000000000Ргеев50 тих ОО0О0000000000 


ООДОД00000000009ипаїрОДОДО"? Саг.0009ипгїРодОДОДО000 
ОМТХОДОД00000000 


О000000000000һра-мЕЋЅІОМ.ёаг.920000000%ЕАКЅІОМр 
Арасһер010000000100Арасћһе 2.2.8000000000РЕра- 
2.4.1 Хаг.92 ОПООООО0000000000000000/ цг/згс/ 


[/usr/local/src/[] 


3.3.2 ПШ 


П00000921р000агра!О00аг.9200000009чпаір00000921рП 
ОО000000000 


ООО0000000000000000000 


# gunzip « httpd-2.4*.tar.gz | tar xvf - 


UUtarbalOUOUUUUUUUUUUUhttpd VERSION 000000000000 
ОО00000000000000 


3.3.3 ППППАрасће 


ООД0000000000000 сопйдигероробробооооО0000000000 
ПППППАрасһеП bb 00000000000/ч5гЛосаї/араспегрр 0 
ОДОДО0О000000000000000Араспебп 


# ./configure 


ОДООО0040ОРНРО00000000000поа зо ОД00ДАраспепо 
ОМІХОДОДО so) ОДОДОДД0О000000АраспердррОРНРеОДДОДОДОДОО 
HOOU0000/usr/local/apache2/Q00ApacheQQ0000000000 
mod 50000000 


й ./configure --prefix-/usr/local/apache2 --enable-so 


сопћаигеПо0000000000000000000000000000000000000 
ППтакећ!іеѕ00000такейіеѕП100000000000Арасһеро00000 
гагдеє5П00000Оплакероррдодбо0б0000000000000000Осопйдиге 
ОО0О0000000000000000000000000000000 


configure ok 


creating test/Makefile 
config.status: creating docs/conf/httpd.conf 


config.status: executing default commands 
= 


ООсопйдаигеррбооооООД00000000000000000000000000000 
ОДбр00000000000Осопд. Іодбсопід аи ОО0000000Д0 
configurer[] |[ | 


DEIEIBBICIEY CIE IILI IILI ILILIAPRII UI! 
пеєра//аргараспе.огд (ОДОДАРЕДАРВ-ЧТОДДОДОДОДОДОДОО 
httpd- ЕВ МПО гс ПБОДОООДОДОДбО0ОООО00000000000000 
ОДОД0ОО00000000000ОРСВКЕПООРЕЄр://мммммм. рсге.огд [LI III! 
ПО\М\е боборородододрообододроророороО 


[Apache 2.2.ХПППИПИПППАрасһе 2.4.хП00000000000000 
ПППП 


3.3.4 (|1 ПАрасһе 


пакеппп п такете$ о ДООД000000000000000пакер 
П000Араспері00000000000000000000000000000000000000 
ПП0000000таке іпѕёа!00АрасһеПтакейіеѕ$П000000000000 
000000 


Installing header files 
Installing build system files 
Installing man pages and online manual 


make[1]: Leaving directory '/usr/local/bin/httpd-2.4.1' 
# 


П0соппоиге000--ргећхо0000000Арасһеро00000 
П/чѕг/Лоса/арасћег00000һрабо000000000000000000000 
ПППП 


й /usr/local/apache2/bin/httpd -v 


ОООО000000000000000000000 


Server version: Араспе/2.4.1 (Unix) 
Server built: March 12 2012 11:47:22 


000000010Мас OS X ПМИпаом ОДАраспедррд000 
П“Араспепп ПОП” НАраспеппип III! 


3.4 [IMac OS XjJ[][JApache 


ОПОООАраспейП О Мас OS ХПООДООД0Араєпердордоро0д 
П/ч$г/5п/ПЕрапО0А (ра. сот ППППППАрасһеП 000000000 


[/еїс/раПППАрасһеЦПЦПШШППШПШПЦИППРНРЦППШШИ`Арасһе[ППП 
ППП"ШШЦШПАрасһеЦПППШПШШПШШШП 


000000000Масє OS XIII IL IILI IILI 02000000 0000ХАМРРОДООООО0О00 
http://www.mamp.info ДМАМРОООО 


ППШШШЦПАраспһе 2.4.хО00УМпаом'в ООДОД0000000000002.2.х000Араспе 
2.4.ХОПООООО000000000000 


Apache 2.20000000У/іпаом 5 ПДОДОДОДОДДАраспе 2.0[ 
Apache 1.ЗПО0000000000000000000Арасһер0000000 
МИ паом з ДООДОДО0000М5УІО000000000 


ОООАраспедрододрбобоороборророрророрродрбууевородо00 
ApachelUUUUUUMicrosoft Internet Information 5егмеп |] 
Microsoft Personal Web Ѕегмег Ц0000000000000000000000 
ОО00УУеббоордоб0орор000000000000000 


ООО000000000000000000000000000000000 
http://httpd.apache.org/download.cgi 0000000000“ y ou 
are downloading the Win32 distribution, please read these 


important notes.” DODOODOOOURLO 
http://www.apache.org/dist/httpd/binaries/win32/README.ht 
ml Û 


Apache[IDHD a DApacher rr Windowsr] 
ОДООД0О000000000000000У/ пасом ПООСООО0О00000000000000 
О00000000000Арасһерроо0000000000000000000000000000 
000000 


ОП0000000000000%1п32 Binary I МБ1ОООООДОД000000000 
ОООО00000000000000000000000031000 


is Apache HTTP Server 2.2 - Installation Wizard 


Welcome to the Installation Wizard for 
Apache HTTP Server 2.2.22 


The Installation Wizard will install Apache HTTP Server 2.2.22 
on your computer. To continue, click Next. 


WARNING: This program is protected by copyright law and 
international treaties, 





03-1 М/паом/ I IILI! 


DON ext IL IILI IILI d db Apacher rii IILI IILI III) 
ООООО000000000000000000000----ОООО000000000000000000 
ООО000000000000 


ООООО0000000000000Арасперродододововороророро000 
О00003-20000000000000000000000Опусопригег. 
пудотаїп.сопПДОДООООЕПЛаїіДоДророророорозодордороодоп 
ОЕ-плайДоОДОООДОО000000000000000000000000 


js Apache HTTP Server 2.2 - Installation Wizard 


Server Information 


Please enter your server's information. 


Network Domain (e.a. somenet.com) 


Server Mame (e.g. www.somenet.com): 
Administrator's Email Address (e.g. webmaster Феотепећ, com): 
Install Apache HTTP Server 2.2 programs and shortcuts for: 


о) for All Users, on Port 80, as a Service — Recommended. 
( only for the Current User, on Port 8080, when started Manually, 





03-2 (000000 


О00000000000000000—==00Арасперо0000000000 
АраспеПрДАраспепПроОбОПДАраспербм/ пасм в ПОДОДО0О0000 
ПОВООЕМАА пом ППВИНИНОВОЕОИНО О Арасте  ПИППАрасһеп 


ПШШПШШЦПАрасһеЦПЦППШППППП8080ЦППП8О0ЦПППШШИШШИИШШИШШИШИШП 
Мех 1000 


ПППППППППППППИПИП бури са ПО сит DE IL I I 
[Typical іпѕќаПайоп00000Араспеп0000000000000000000 
ОООО0000000000000000000 


ПППИППСивбога  ипосаНанопрророообооооооовоовоооо0о 
ППППСЛРгодгат Files\Apache Software Foundation/Apache 


2.2 ПООООО0О0О00000000000000003-300000000 


ІШ Apache HTTP Server 2.2 - Installation Wizard 


Installation Wizard Completed 


The Installation Wizard has successfully installed Apache HTTP 
Server 2.2.22. Click Finish to exit the wizard. 





03-3 (000008 


ООДООДО000000Арасперододоророророоооо 


3.6 Apachel [000 


АрасһерПО0000000000000000000001һра.соп ОДО0000 
LLL HA pa cher TIU (Directive)[IiApachel|[ libb 
ОДОД0000000СопіаіпегодороДОД000000000000000000000000 
ООО00000000000000 


3.6.1 || 


ОДООО000Араспероо0 


ОО0000000000 

° ПИ 

• ПООООООДО0000000000000000000 

• ПООООДОООООООО0О000000000000000000А000000000000 
ULL] 

0000зОбО0000000000000 


Араспердоооо 
http://httpd.apache.org/docs/2.2/mod/quickreference.html [| 


ОООО00000000000000000000000000000000000000000000 


ООДАрасперрдророо00000 


Description —— -ОДОДО000000000000 

Syntax —— ОДООООО000000000000000000000000000000 
000000 

Default - - -ОПООО00000000000000 

Context ----ПОПООО000ДОб0000000000000000000000000 
ППвегуег config[]virtual host[]directory|[].htaccess[] 
override ——Apacher[]Irlbi iir everrider ble Db d IU 
UUUUUU.htaccess рег-шаїгесрогу Пд ППП 

Status —— ЧЗДОДОДОООПОАраспе(соге) ПДОООДО00000000 
Оба5еДПехсеп5іопПОДОООДОО00ОД0000000000000Митбіч 
Processing Моде ОМРМ)ДОДООООАраєперродороро000 
Пехрептепёаі 0 

Module —— 00000000000000 

Compatibility ----ОПОООО0ОДО00000Арасперодооро 


ООООО000000000000000000000000000000000000000 
3.6.2 || 


000000000О5есбопродрбООО0000000000000000000000000 
П000000ѕегмег config III III III II II 


ООДАраспердродо0000 


e «VirtualHost» ——-VirtualHost[ ПП ПАрасһеЖеПП 
HEBIBBBBA pacheD i Webr]lli ni E iD miDIDEI EET We п 


ООО000000ІРООООО0000000000000000290000000000000 
ПЦ 

е «Directory», <DirectoryMatch> —— ПППППОООООООО 
ОООООД000000000ігессогу ОООДО0000000000000000000 
ППППИППИППИПППРІгесоогуМаге в ОПОООООООО00000000000 
00000000ОПмумуу  ПОООООООО0000000000400000000000000 
002120020 1 2L 200000000 


«DirectoryMatch "^/www/.*/[0-9]14?"» 


е «Location», <LocationMatch> ——I[J Ip] 
ПОВЕЛОВЕДОДОДО є Directory>, <DirectoryMatch>[][][] 


|осапопма слоооооооооооооовооооооооо 
П"/ пу/даїа"П"/уоиг/дана" 0000 


«LocationMatch "/(my|your)/data"> 


• «Files», «FilesMatch» ——/[]][|Directory[JLocation[][] 
HOFilesQUOUU0000000000000 


ОО00000000003.12000 


00003.1 ОДО000 


: <Directory "/some/directory"> 
: SomeDirectivel 

: SomeDirective2 

: </Directory> 

<Location "/downloads/*.html"> 
: ботеПігестіуез 

: </Location> 

: «Files "\.(gif|jpg)"> 

: SomeDirective4 

: </Files> 


& O on7nnnr G мо 


— 


HEEIEISomebDirectivel[|]someDirective2|][][] 
[/some/directory[|[ JULI LUSomeDirective3| [| OOOOH. Atm ly 
[LLILILIURLI I | LIL L /downloads/URL||[]SomeDirective4l|||[ | |[ |[ | 
0.9і0)99000000000 


3.6.3 (ІП! 
АрасһерПОО0000000000000000000000000000000 


[directives enclosed[][] 


° <IfDefine> ——0О00000000000000Арасһепр000000000 
ООДО00000000-0МумоайітедроДОД00000Арасперрдор0000 
О0000003.2000000000000000000000000000арасһесіП 
ОО0000000000000*Арасһероо00” 00000 


І#ейперо500000000000000000-0МуМоаџиер000000000 
ЦЦ<!Шейпе ! МуМоаише>0000000000МуМоашеро0000000 


° <ifModule> ——0000000000000%ею000000#ҸМоаие 
ООДООДОО000000000Арасперороооомеморооооо 
пёра.соп#О0000000000003.З00000000000000Арасһерд 
МРМЕЦОООООООООООООООООООООООООООООО 


0003.2  IfDefiner[ll] 


1: «IfDefine MyModule- 
2: LoadModule my module modules/libmymodule.so 
З: «/IfDefine» 


00003.3 Module] 


: «IfModule prefork.c> 
: StartServers 


1 

2 
3: MinSpareServers 5 
4: MaxSpareServers 10 
5: MaxClients 20 
6: MaxRequestsPerChild 0 
7: </IfModule> 
8: 

9: «IfModule worker.c> 
10: StartServers З 
11: MaxClients 8 
12: MinSpareThreads S 
13: MaxSpareThreads 10 
14: ThreadsPerChild 25 


15: MaxRequestsPerChild Q 
16: </IfModule> 


3.6.4 ServerRoot| | | 


сегуегкоо ДОООООДДОО000000000000000000000000000 
ПО000000005егмуегАоої TTL E] і пих/ОМІХОДОДОООАрасперо 
ПППППППбегуегВооПППЦ/ивг/оса/арасһе2ПППМас OS ХППП 
бегуегКбоо ПШ/ыргагу/ЛУеббегәегіі JULI UWindowsl ПППОП 
бегуегВооЦПППСаАРгодгат Files\Apache Software 
Foundation\Apache 2.2\[] 


3.6.5 per-directory||[][][ 


Apache(|per-directory ПОПОДОООООООД0000ОРЕр сой 1008 
ПОДОДО00000000000000000000000000000000000000000000 
ПООООДО0000Араспердороро0000000000ОПрег-дїгессогу ПП 
ПППППППППППГГПППАрасһеП ПП iLl/usr/local/ 
apache2/htdocs/index.html[| | JLI Мат ал оса 


usr/local/apache2|J/usr/local/apache2/htdocs|[|[ | JLI Iper- 
directory[ IU] 


П00рег-аігесёогур00000.һассеѕ$0000000000000000000 
ПИПИПНТМЕППИПППИП 


AccessFileNamel||[ | JL Iper-directory[ 00000. Ппкассе55 |[ |[ | 
ОДООО000000000000000Прегаїгессогу ДОООАрасперродоо 


ОДО00000000Прег-їгессогу  ПОДОДОДО000000000С0піехі: 
LEID CIEL]. htaccess ПНАраспепррр0О000000000000000Омеггіае ПП 
О0000000муепліаеродо III IL 


• AuthConfig ——П0000 

e Filelnfo ——000000000 

° Indexes —— | lr] 

e Limit ——000000000 

e Options —— 0000000000 


LOB EAM wOverriderj in tbib iii lii i per-d irectery 000 
ППАНОомОмегтае ПОДОДДАТІИО МопердрдАТОДДООООДО0000000000 
О0000Мопербодорородооо000Орег-аїгессогу 0 О00000003.4 


ООДО000000000000Прег-дїгессогу ПП ПП 
АрасһеППП 


00003.4 ППрег-вігесіогу ІП 


1: «Directory /> 
2: AllowOverride none 
3: </Directory> 


3.7 Арасһе( |11 


ПОООООАраспейП ПП ПППассес5 І90О0000000000 
error ІТОФП ОООДОДООООО0О00000000000000000000000Араспер 
ППООООДОДОО\МЛ о Аомм“$ ПОООДассе$$.1о9 еггог. lool 


3.7.1 access Іо0) || 


ООООО00000000000АраспердододововорбородроріРорО000 
OOOH T ТРОДОДОДОДОГДООЗ.5000000000000026000000000000 
OOL 


О0003.5 access ІОӘППІП 


1: 127.0.0.1 - - [12/Mar/202:08:33:25 -0700] "СЕТ / HTTP/1.1" 200 44 
2: 127.0.0.1 - - [12/Маг/2012:08:33:25 -0700] "GET /favicon.ico HTTP/1.1" 404 209 


3.7.2 error log[[] 


error ТодПДОДО ОДОДОб0О000000000000000000000 
АрасһерО000000000000000000003.6000еггог legii 


О0003.6 error 199 (000 


1: Starting the Apache2.4 service [The Apache2.4 service is running.] 

2: Apache/2.4.1 (Unix) configured -- resuming normal operations 

3: [Tue Маг 13 98:29:34 2012] [notice] Server built: Mar 12 2012 11:47:22 

4: [Tue Mar 13 08:29:34 2012] [notice] Parent: Created child process 3504 

5: [Tue Mar 13 08:29:35 2012] [notice] Child 3504: Child process is running 
6: [Tue Mar 13 98:29:35 2012] [notice] Child 3504: Acquired the start mutex. 
3.7.3 ПППП 


httpd.pid[] [DD Apacher]pp mm pp p III I UTE 
Араспедд0000000000 0 согебоага | ППЧпих/9МХ Арасһе[[Ц 
ОДОДОДОО00000МРУМОДООООДООООДО0ОДОО0ОД00000000000 


3.8 АрасһеГ(| |11 


Арасперрдооброродорорб00000000000000000025000290 
ООДАрасперрдророобо000 


3.8.1 Арасћец ПО 


ApachelUUUUULinux/UNIXJMac OS ХППОЋЕ радомлпаом/5 
0ООараспе ехердД000000000003-1000000000001їпих/ ОМІХ 
П00/иѕғг/осаі/арасһе2/0іп/Һра -h ППМас OS ХПП 
[]/usr/sbin/httpd -h ПОЛУ паом50000000ОДараспе.ехе -h 
ООО000000000000 


[3-1 ПераП 


HICIEIDIEIDIEID UL e ÉD efine 2 00000 


ОО00000000000 
ООДОДОД000000000РЕр.сопі) 00 


АраспеппП ПО Ничх/9МХОМас OS ХО00КШО0000000 
АрасперорообородорбоорородорббдроодоророрО0 


й kill -SIGNAL pid 





n О00000000000 


ООДОО00рІФООДІООО519 МАЄДООООДОЮ 


° HUP — 000000 
° USRI[IWINCH ----ОООООО0О000000000000000000 
° SIGHUP — —([ID D] 


ОДОО0О00000000000000000000000000Арасперроро00000 
ОДОО0О0000000000000000000000000000000Араспердодой( 
0000 


ОО000000000000000000000000000000000000000000000 
ОООООД000000000000000000000000000000000000000000000 


П\/\/ерРЦППППППППЦПЦШИШИШШШПП 
ПЦМЛпаоуу$5ЦЦПЦПЦЦППЦПЦарасһпе.ехеЦПППЦЦИЦПИЦПАрасһпе[ 


е apache.exe -k гесҒагЕ-( АрасһеП(ІППП 
е арасһе.ехе -k graceful —— |Араслпедуоооооо 
° apache.exe -k stop ----ПЛПАрасперПП 


ООООО00000000А pa ch er lb p p E E E EI DE iA Pa eher 1 
ООООО00000000УМі пом ПДООООООДАрРасперрророороб0р000000 
0000000 


3.8.2 Арасће[|||| 


ПППИпих/ОМІХПППһ райпо UA pa che EDD DD I III! 
арасһес0ПарасһесОО000000000000000000000000 
арасһес 0000000 


# /usr/local/apache2/bin/apachectl command 


ПО сога тата Дор ]start[]|restart[]graceful[ 0000 
Парасһес00000000000000000005000000000000АрасһеП0 
ПОО00000000 


3.9 ( ПППАрасһе 


П00АрасһеррО0000000000000000АрасһпеП00ћра.сопї 
ОПО00000000000Арасһпербо00000000000 


3.9.1 ML 


ППППППППИППППППАрасһе Пера. со ПОП пих/ОМІХП 
Мас OS ХД)0000міОепася ПОМ\Апаоми ППИПИНИИНИНИВИВИПИЕ 
ППИПИПИПИПИППАрасһеП( ПП ПП 


ПППППАрасгһеП ПП Пп ПП 0000000 
ОДАрасперодОооД00000000. 00000000000 


АрасперрдооОбОДІРООООДОДООДО0О0О0ДО00О00О0000000000000 
ОМ5ДООДО0000000001РОООООООООДОО0О0О0О000000000000000 
П00АрасһеП000000127.0.0.10000000000оорраск 
ааагеѕѕ,00000800000000000000000080000000000000000 
ПОООО Ч ®чх/ОМИХОМас OS ХО000000000000гооО00000000 
0000002 0240000000000000000000 


ОДО0ОЬ15епДООООДО000000Ь15сепООООДО0ОО00000000001Р 
ООДООО0000000000000АраспердодоооВО0ІРООДОДОСОСО3ОДО 
ПППППППИРОППАрасһеП ППТ ПП ПЫ5геп 8001 
ApachelUUPUUUUUUSOUUUUUULIsten 10.0.0.1:443ППАрасһеП 


0010.0.0.100443ПП0 


зегуегМ аттепдоОбОО00000000000000000000000009К000 
О0000000 М5О0000000000000000000005егметматердрнорцП 
ООО0О000000000000000000000 


[]Linux/UNIX[]Mac OS Х000000000У5ег)остгоир EDIDIT IL 
О000000010р000пороаупоооо00000000000000000009Р-ОХрП0 


IIIHDII IILI IILI IILI IIDII IL МАМА 
3.9.2 ППАраспе 


ППИпих/ОМІХДППАрасһеП ІІ Парасһес ЦИП 
ПП 


# /usr/local/apache2/bin/apachectl start 


Mac Оз ХООООПООНОООООООНОО 


й /usr/sbin/httpd 


ПОМЛпаом/ ПППППАрасйпейПППОООПАрасйе HTTP Server 
2 2ППП ПОопігді Apache ServerT][][][L][]]|Start Apache in 
Сопсоһе | ПППППАраспепи В ВИО НАраспеппп 


О0000000000000000Арасһеро0000000000003-40000000 
ООМуеооо00000000000000000*0000"00000000ѕёепоо000000 
ОПОДОДАраспе----0008008080000 


C localhost 


€ C ©) http://localhost |] M 3 


It works! 


03-4 ПППТПАрасһе 


3.10 |ІІІ 


III III IApache[III II III вов 
3.10.1 [| Web||[[|[| 


ПППППППИППППППИПИППИППІРПППИПИПИПАрасһеП ПП ПП 
ОДОД0О0000000000000000А распероро0000 


[crit] (48)Address already in use: make sock: could not bind...[alert] no 
listening sockets available, shutting down 


ООДООДО000000000000000Арасперродоор000000 


3.10.2 [III 
ОООО000000000000000000000010240П0000000000000000 


[crit] (13)Permission denied: make sock: could not bind to address 19.0.9.2:80 
[alert] no listening sockets available, shutting down 


ОООО0000000000А pa ch er bp p OE E ово 8 O1] ri TTL 
0000000 


3.10.3 [JOOU 


ОО0000000000000000000000000Арасһепро0000000000 
ПП 


(13)Permission denied: httpd: could not open error log file 


ОООО000000АраспербАрасперорроророоророрододоооцО 
ПП 


3.10.4 |ІІІ! 


00000Арасһперо0000000000000000000000000Арасһер 
О00000000000000000005$еёоіа: unable to set group 140000 


LI L]Einux/UNIXT]Mac OS XIII IILI IIILI LIL О бгочробоо 
LIBICIEETEIEIEETDEIEIETEIEIL/etc/greu psu 


3.11 | 


ПОООООЧичх/9МХП Мас OS ХПМіпасм 5 ДОДОДАраспе 
2.2 ОООООО00000000000000000000000000000000000000000 


ОООДО000000000Арасперррооодооророророророродродо 
access |одПеггог Іо0000000000шпох/ОМХОМас OS ХП 


УМ паом'вОДДОООДАрасперророОДАрасперродророробоб000000 


3.12 О&А 


ОбОООО000000000000 


АПОДОДОООООООДОДАрасперрдороророорородоросооцо 
ПППтаке сіеапр0000000000000000000000000 


Q[Iper-directory[|[[ [II II I I 


АП00рег-аігесёогупуоо00о00000000000000000000000000 
П0000рег-аігесёогурооо000000000000000000000 


О0000%УеБро000000000000000000000000000000000000 
00000000 


О зетегМате о p I III! 


АПОМЪПИПОПЕИРИНОВОПОООНОВОВОСОВУАЕОО 5 erverName 
ООДОО000000000000000000М50О00000000000000000 


3.13 (ULL 


ОО0О00000000000000000000000000000000000000 


ЦЕН 


10000000000АрасһеП000 
2[]«Location-[]]« Directory 00000000000 


ЗППШШИШШШШШШШШ 


ИЦ 


10ипох/ЧомХха00000соппоигеццц--ргейяхо00000Арасһер 
ОООО00000000000000000000000000000000000УМїпаом 50000 
ПООДО000000000 


2001ігесёогур0000000006осасопр00\Мебпо000000000 


3LIIILIILILIIILI III IILI ILI II! 
Арасһер/ОО0000000000000000000000/000000000 


ӨШ 


1ОДО00000000000000000000 


2 ДО00000000000900005егуегМатерр 


I41 ОООДОРНР 


00000000 


° ПОДОРНРО 

° ПОДОРНРОДОД 
° (ПП 
° ПООРАНРОГО 


ОО000000000000000РНРО000Араспероб0000000000 


4.1 PHP 


ОООО000000РНР 5.4.0000000000000 


PHP СгоиррП00000000000000000000000чөро000000000 
ООООО0000000000000000000000000000РНР Groupliu IU II II! 
0000000 


О00000000000000000005.4.2000000000000000000000 
http://www.php.net/ChangeLog-5.php ОДОДОДОДОДДОД/ 0000 


ООО0000000000000000 


ОО0О0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 


ОО00000000000000000000000000000000000000000 
4.2 (ППАрасһеГіппих/ОМІХГТТІРНР 


О000000000000Арасһедшпих/ОМіІХО00РНРО0000000000 
ОООУМІХОДООООСОДООО00О000000000000000РНРОДОДООДОДП 
ООООООРНРеОДОООООООООООО0О00000000000000 


[IL IPHPIII LI II IPHPII[ II Ihttp://www.php.net/ 00000 
РомпіоааѕП0000000000000000000005.4.0000000000000 
рһр-МЕВ5ІОМ.ғаг.92600УЕК5ІОМП000000000000000000000 
Тап 


# gunzip « php-VERSION.tar.gz | tar xvf - 


ПППЦПППЦППИПЦПППППППППП/ч5г/5гс/[/ч5г/!оса1/5гс1ПППППП 
ПОООООООРАРООООО 


# са php-VERSION 


ООО00000000000000сопйдигеруро00000Осопйачтерб 0 
ОООДО000000000000000000000000ОРНРеОООДООООО000000000 
ПОПОАраспе Му ОРОДО ООРНРООООДОДО0О0О00000000000 
соппачгетп ПП 


# ./configure  --prefix-/usr/local/php \ 
--with-mysqli-/usr/local/mysql/bin/mysql config | 
- -with-apxs2-/usr/local/apache2/bin/apxs 


LOB CIMySQLEApach eni m p ооророророреор0О 
ООО000000000000 


ОО000000000000000 


Generating files 

updating cache ./config.cache 
creating ./config.status 

creating phpb5.spec 

creating main/build-defs.h 
creating scripts/phpize 

creating scripts/mani/phpize. 1 
creating scripts/php-config 
creating scripts/mani/php-config.1 
creating sapi/cli/pho. 1 

creating main/php config.h 
creating main/internal Tunctions.c 
creating main/internal functions cli.c 


| License: | 
| This software is subject to the PHP License, available in this | 
| distribution in the file LICENSE. By continuing this installation | 
| process, you are bound by the terms of this license agreement. | 
| | 
| | 


If you do not agree with the terms of this license, you must abort 
the installation process at this point. 


Thank you for using PHP. 


# 


П000000000такер00000таке іп5са ПОООООД0О0ДОРНРО 
ОО0000000000000000 


chmod 755 /usr/local/apache2/modules/libphp5.so 
[activating module 'php5' in /usr/local/apache2/conf/httpd.conf] 


Installing PHP CLI binary: /usr/local/php/bin/ 
Installing PHP CLI man page: /usr/local/php/php/man/manli / 
Installing PHP CGI binary: /usr/local/php/bin/ 
Installing build environment: /usr/local/php/lib/php/build/ 
Installing header files: /usr/local/php/include/php/ 
Installing helper programs: fusr/local/php/bin/ 


program: phpize 
program: php-config 
Installing man pages: fusr/local/php/php/man/mani f 
page: phpize.1 
page: php-config.1 


й 


ОО000000000000000000000000000000000рпһр.тр00000 
ООО000000000000000000рпһр.ітћі000000 


# ср php.ini-development /usr/local/lib/php.ini 


О000000000000РНРрОБ000000Арасһероо0000000000000 
О000РНРО0000000таке insta Hp] pb pb pp i i ED ED IILI LI TL 


й cp libs/libphp5.so /usr/local/apache2/modules/ 


ПППППППИПИППАрасһеП ППТ О пих/(ОМІХОДОРНРО 
Араспе"ПОДОДО0ОО000000000000000 


4.2.1 ([00Linux/UNIXQ000 


ОО0000000000РНР сопйдигедрПООООДОДОДОДОО0000000 
РНРО00000000000сопћоигероо000000000000000000000000 
ОООДОРНРДОООДООО00000 


ї ./configure  --help 


ООООО00000000000000000000000000000000 


4 ./configure --help > configoptions.txt 


ОДООРНАРОООДОООООООООО0О00ООРАРООООООДОООО0000000000 
О000000000юрһрҳ.ѕорп000000Араспероо000000000000000 
ПАраспеппппппп 


4.2.2 Піших/ОМІХПИОРНРОАрасПпе 


ОДОРНРОАрасперодродородДороРеЕра. cont 10000000000 
ООО000000000000000000 


LoadModule рћр5 module nodules/libphp5.so 


ООООО00000000000000000007 # ОООДО00000000007 # ШП 
ОДОООАраспероРНРООДОООДОРНРОДОДОД(ТЬРрАр5.50)0 


ОО000000000 
# 
# AddType allows you to add to or override the MIME configuration 


& file mime.types for specific file types. 
Я 


ООО00000000000000 


AddType application/x-httpd-php .php 


ПООООООРНРООООООО. phe D hem ПОПОИОПОНОВОВОВОВОВОВ 
ULL] 


ELCIDEIDEIEIDIEIEICID EA pa che (III I Петтог Teg Tibi pii T 
ULL] 


[Tue Mar 13 10:42:47 2012] [notice] Apache/2.4.1 (Unix) PHP/5.4.0 configured 


РНРПППППАрасһе УУ-БДООО0О000000000000000Мас OS ХП 
ООООРНРОДОООООО000000007 00007000 


4.3 [IMac OS ХИППРНР 


ООДАрасперМас OS ХЮДОРАНРООДОДОООПО0ОО0ДО00000000 
ООООДО00000000000000000000000000000ОРНРОДООМасрогіє 
([]http://www.macports.org/ ПППППППХАМРРПППИПИППМАМР 
(Uhttp://www.mamp.info УДДОДО0Д0000000000000002.200000 
ULL] 


4.4 (Млпаом5 РНР 


ПМлпаом50ПОРНРООООООООООООООООРНРОРООООООР НРООЦ 
http://www.php.net/ ПППППППОРоууп!оаа$ПППППППППП2!РПППП 
О000000000005.4.0б00000000000000ПрОРр-УМЕВУІОМ. ГОЛО 
МЕВЗІОМПООООО0О000 


ОООО0000000000000000000000000000000000000000000 
ПОСА рар ПП пп ПВ ПИ 


ПОПИС лећолррОООбОоћр ип!-гесоттепаеайППрир. и 77 
ОООАраспердодоРНРОДОДООДОДОО0Араспероороо0о0000000 


ППГМ/ІпаомуӘ ППППППИПИПИППППГПИГПИГППРНРППИПИПИПИПИПИППГПГИПИПИГПГ x 


ПОВОВЕНООВОСЕВОВОВОВООВОВООРНРИЕООПРАТАПОВОВЕВОВОВОВЕ x 
http://www.php.net/manual/en/faq.installation.php#faq.installation.addtopath П 


PHP БАОПООООЦ 


[Windowsi| j UPHP[I|JApache 


ОДОРНРОАрасперодрдрородоВодира. сол т (IILI LI III! 
ПОООб ра.соп 00000000 


Я Example: 

й? LoadModule foo module modules/mod foo.so 

# 

LoadModule access module modules/mod access.so 


&LoadModule vhost alias module modules/mod vhost alias.so 


ОО0000000000000 


LoadModule php5 module С: /рћр/рћрбарасће2 2.411 


ППОПОВОВОВО О Араспе Прир ии 0101 


PHPIniDir "C:/php/'" 


ОО0000000000 


# 

# AddType allows you to add to or override the MIME configuration 
& file mime.types for specific file types. 

if 


ООО0000000000000 


AddType application/x-httpd-php .php 


ППИПИПИРНРПИПИПИП  рир 0. hem ПОПОПОПОНОВОВОВОВОВОВ 
0000 


ППћра.соп0О0000000Арасћероб00000000000РНРО000 
[Apache МебрП0000000 


4.5 php.ini[][] 


ППППППППРНРПППИПИГПИПРАр и DEIDEIDIEIDI EIE Ei u x/ ОМІХОД 
О00000000000/чѕгЛосаі/рћр/тороо0000000000РНРОП000000 
ОООУМ паом5 ПООДОДОООДОРНРОДОДОДОАРасте httpd.conf 
ОРНРІПІОГОДООООО000000 


рир.іпіДрДобОДОООД0О0000000000000000000000000000000 
ООООО00000000000000000000000000000000000000000000 
ОДО00000100пДуез пгиероОООДОДОбОМорРатьер 000 


ОММіпаом'600000000Оехеепзіоп аїГДОООООООДОДДОРНРОДОСАрЕРОД0000 
extension аіг0000“С:\рһр\ехі”р 
ООДОД0ОриріпіорборордрООО000000000000000000000000 
ПООООД000Д0ОрРро ri дД00000000000 


4.6 [II 


ПОРНРОДОДООДОО00000РА pinfo 0000000000000000000000 
ОООО00000000000000000000000000 


«?php phpinfo(); 9» 


ПО000000рһріпѓо.рпро0000000%ебро0000000000 
Apache[j][]]]htdocs[TTHEHE]IMac OS ХП 
[/Library/WebServer/Documents[][]t|I:Web[LQLDLDLDLDIELILILILILILTETETLILI 
4-1000000 





e phpinfo 
€ С! © http;//localhost/phpinfo.php кі M ~ 

[System [Windows NT JM-PC 6.1 build 7601 (Windows 7 Home Premium Edition Service Pack 1) i586 

Build Date Feb 28 2012 19:20:16 

MSVC9 (Visual С++ 2008) 

Architecture 
cscript /поїодо confiqure.js "——enable-snapshot-build" "—disable-isapi" —enable-debug-pack" 
"—disable-nsapi" "—without-mssqr "—withaut-pda-mssql" "—withaut-pi3web" “—with-pdo- 
oci-Cphp-sdkioracleunstantclient1ü0lsdk, shared" “—with-oci8=C:iphp- 
sdkioracleinstantcienti sdk shared” "—with-oci8-11g-C^php- 
süaákaracleunstantclient1 Tisdk, shared" ——enable-abject-out-dir-./abj" “—enable-com-dotnet 
"—with-mcrypt-static" "—disable-static-analyze" "—with-pgo* 

4 | 





04-1  рћрито 0000 


phpinfo ПОООООООД000Д00ДОРАРОДОДОДООО 


4.7 000000 


ПО тегле И ОПОООДО0000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО00000000000 


ОДОДООО000000000000РНРООДООР'ЕЄрм//мммммм. ph p. net/ 0000 
ПООООО Ер ://ww w. ph p.net/manua t ВО000000000000000РНР 
ОООО0000000000000000000000000000000000000000000000 
[]http://www.php.net/search.php ППППИПИПИПИПИПИПРНРЦИПП 
ОО0О0000000000000000000000000000000000 


ОДОООО0000000000000РАНРеООООООДОО00000000 
http://www.php.net/mailing-lists.php ПООРНРООООООООООООО 
ОДОООО0000000000000000000000000РАРеБООООООДО0О000000 
ОООДО00000000000000000000000 


ООООО0000000000000000000000000000000000000000000 
ОО00000000 


° ПШПШ 

e ПОДОООООРНРООО 

° (ПП! 

• ДЮрррОООсопйайгедпакерроо0000 
• ПОООООООО0000000000 


ООО00000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000 


ООООО000000000000000000000000000000000000000000 
ОДОООО0000000000000000000000000ОРАРОБООООООД00000000 
ОООО00000000000000000000000000000000000 


ООООО0000000000000000ОРНРОДОООДООООООО00000000000 
ОООО00000000000000000000000 


4.8 PHP 


ОДОДОО0ОРНРОООООООООДОО0ОО00000Н "МЕДООООРНРОДОД 
ОДБОДОО00000000000000000000000000000Н PM EOD ET TE] 
ПООООООООРАРЦ 


ООРНРООО00000000000Оммммми рир-еаїсог5. сопПОДОДОДО 
4.10 Bp Web p Ea id ifiest. php 


00004.1 ОООДОРНРОП 


1: «?php 
2: echo "«h1»Hello Web!</h1>"; 
di 7> 


ООДОО0ОРНРОДОДООООООООО00000000000Р T PETS CPCTITIBIDIDIETE 
ООООО0000000000000000000000000000000000000000000000 
оробр00042000001йт52рАрРО000 


© lacalhost/first.php 


< C | © http://localhost/firstphp 


Hello Web! 





04-2 O0:00first.phpoo0 
4.8.1  ПООООДОРНРОПО 


ПООРАРДООООООПОРАРОООООООООООООООООООРАРООООО 
ПТ О О О О О О О 00 
РНРООООООООРНРОООООООООО04- 1000А0РНРрО000 


14-1 PHPTIIDULILI 


0000 0000 0000 


ш ص‎ ` 
pooo <script language="php"> 





004-1000000000000000000000000000000000А5РО00000 
рһр.іпі0000000 


ОО000000000000000рпһр.іт!005ћогё open tag riiront] 


short open tag - On; 


ОДОДА5РОДОООООДОСОСОРЕР. іпі0Оазр tags IEIEOnt] 


asp tags - On; 


ОДООО0О000000000000000000000000А45 РОПООООПООООООООООПООООООООООГО 
ОО000000000000000 | 


ООДОрИріпіоДО Ї00Арасперродродроророрововоророооо 
ОООДО00000000000000000000000000000ХМУ0О0000000000 
(<? ?>)0000000(<?рһр 7200 


0000 < ОДО0Х МЕДОДОДОООООООДОДООО00000Х МЕДООООООДООДОДОХ МЕ0Д00000 ) 
ООРАРОДОООООХ МЕОООДООРНРОДОООДОООООД0ООО00Х МЕООООДООООП u 


ОО00000004.1000000000000000000000040РНРрООО0000 
000000 


«7 
echo "Hello Web!"; 
2> 


<?рһр 
echo "Hello Меб!"; 
T» 


<% 
echo "Hello Web!": 


957 
«script language-'php'» 


echo "Hello Web!":; 
«/script» 


ОООДОО0000000ОРНАРООООООООООО000000000 


«?php echo "Hello Мері"; 7» 


ПОООООООООООРНРООООООООООООООООО4- 1000000 
4.8.2 echo] ]Jprint()[] 


Ор00Оеспорроброд0р0000000000есвородОДООб00000000 
ОД00000ргінєО0000ОесподдОООесподргіпєООДбО00000000000 
ООО000000000000000 


ООООО000000000000000000004-10000000000000000000 
ОРНРОДОООООООООООО0000ОО0000000000000000000000 


ПЦП5аїтетеп ОООРНРОДООООООООООО0ОДОРНРОООДООООО 
ООООО0000000000000000000000000ОРАРООООООООД00000000 
ООООО0Д000000000000000000000000000000000000000000000 
ООО0000РНРО0000000000000 


4.8.3 (ОНТМЦ ЈРНР 


00004. 1000000ОРАРОООДООООДН ТМЕООРНРОДОООЗОДОДОД 
ООО000000000н 7мЕ00)00000002.2000 


00004.2 = ОООНТМЕДОДОРНРОД 


: <!DOCTYPE html» 

: <html> 

: «head» 

: <title>A PHP script including HIML</title> 
</head> 

<body> 

: <h1><?php echo "hello world"; ?></h1> 

: </body> 

: </html> 


осо со ыч O) n + woh = 


ООООО0000РНРОДОООООД0Н МЕОДОООООО0ОДОООООРНРОПО 
ОРНРООДОДОДОДОДООДОДОДООООДА-20000000пеПомогіа рирб 
О0000000000000000000000004-з00000000000һеПо world ITE] 
оборр0000004-Ф0000000000000000Н TM Loo 





(С) A PHP script including НТ! 


= CQ http://localhost/helloworld.php 


hello world 


04-3 helloworld.phpUUUUUUUUUUU 


e view-sourcelocalhast/hell 


N SP гру P" P” | = Ts | = | = ир" | == | ym : =a 
C G) view-source:localhost/helloworld.php ~ le M A 


4| «title-AÀ PHP script including HIML</title> 
5 | </head> 

a| <body> 

7| ehl»hello world</hi> 


[4-4 helloworld.php(LLLIH TM LLL 


ОООДО0000000000000000000ОРАРОООООООООО000000000 
О'МЕДДООДООООООООООД0О000О0000000000000000000000000000 
ООО0О0000000000000000000 


4.8.4 ПРІНР5РОООЛООГ 


ОООО00000000000000000060000000000000000000000000 
ООО0ОО000000000000000000000000000000000000000000 


ПО соттттей ОООООООРНРОДООООООООООО0ОО0О0000000000 
00000000 


ОО00000000000/7)0000000000000000000000000РНРО0000 
ОДОДО00000000ОРНАРОООДОД0О0000 


// this is a comment 
й this is another comment 


ОДОООО0000000000000Р90О0000000000000000000009/00 


/% 

this is a comment 
none of this will 
be parsed by the 

PHP engine 

* 


4.9 ||| 


ПППППППППППППИлих/ОМІХПМас OS ХОМ/іпаом в ДОДО00 
PHP 5.4.00000Арасһћер0000000пих/ЈміХрПО00000 
соппоигеПО0000000000000000000000рпр.ті00000000000 
ПППП 


ППрһріпғо()О000000000000000000000000000000000000 
ПООООООРАРОООООООООООООООООРАРООООАОООО 


0р000000000ДОесподООрпіпєООДОО0000000000НТМІОРНР 
ОООДО000000000000000000000000ОРНРеООООООООО0000000000 
0000000 


4.10 Q&A 


ОПТТПППТПЫИтих/ОМІХГМас OS ХПМлпаом/5 || 
Apache Мер  ППОРНРООДОООООООООПОООО0О000000 
OULU 


АОООООРНРООООДОООООООООООООООООО000ОРНРОДОДООООО 
УчерБ ПООДООДОО0 О000000000000000000000000ОРНРОМУ5О 
Арасһер000000%еороо00000000000000000000000000 
ОбООО00000000000 

АПОДОДОООООООДОДОДОО000000000000 <?php ?>)0000000 


ОПОООРНРФООООДОО00О0000000000 


АПОООДООО00О00000000000000М icrosoft ММогапро00000000 
ООООО000000000000000000000000000 


ОбООО000000000 
АООООООООООО0ОО00000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ПП 
HOOLI 


ООООО0Д00000000000000000000000000000000000000 


ЦЕН 


100 пих/ОМІХОДОООООООООПООООООООДОРНРОДОД 
соппачге IILI III 


2 П00000000.рһео0000000000Арасһеро000000000%* 
ЗОРНРООДОО00000 


А4ООО000000УУебороОДОООДОО00РНРООООДОДО 


ИЦ 


ТОДО0Д0ОРНРДООДОДОСопИдигер000--ПетророОроДОЗОД000 
ОО0000000000000 


./configure --help 


2)00АрасперрО. ph РООООООДОРНРДОДОСО3ОДО 


AddType application/x-httpd-php .php 
ЗПРНРОДОДОДОРИР.іпі0 


АД О0000000000000000 


ЦЕН 


1 ПООДО000ОРАРОДООДОООООДРАРАНІОДОДОДОДОД 


2 П0000000000РНРрО0000000000000*һео world” ДОД000 
ОНТМЕПОООООООООРНРОООООООООРНРООООООООООООООООООО 


HOU Ap. «пІППППИППППППППИПИПИПИПИПИП 


050 
П6Г 
070 
081 


N90 


ЕЛДЕ 


РІНРОДООО 
РАНРОДОСООО 
0000 

HOOLI 


0000 


РІРОДОД 


050 РІРеОДДОД 


00000000 


(Ш---- ИИН 
ОО00000000 

00000 

ОО00000000 

ОО000000000000 

ОО00000000 


ООООО00ООО0ООООРНРОООООООООООООООООООООООООООООО 
ООООО0000000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000000000 


ОООО0000000000000000000000000000000000000000000 
ООООРНРОДОООО 


5.1 [| 


ОООмапавіе пДоО00000000000000000007 007" 000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000000000000 


есћо (2 + 47; 


ОООО00000000000020А0000000000000000000000000000 
ООООО0000000000ЗО0500000000000000000000000000 


ООООО000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОО00000000 


ОО000000000000000000000000%00000000000000000000 
00 ПООО000000000000000000000000000000000000 


$8; 

$a longish variable name; 
$2453; 

$sleepyZZZZ; 


ПОДО000000000000000000000000000патедоробразулога ДО0000000000 | 
$ пООООООО00005РОСОО0000000000000000000000000000000000000000000000 . 
зпОДО"питег"000"пате"ООД00005Р00"раде" 000“ password" 0000000000000 
ОДО0000000005п05Р0000000000000000000000000000000000000000000000000 
000004 | 


[LLL LIL Lin stru ction terminator ОДООДОРНРО 
ПТ О О В В В О ОТ 
ППЦППЦПИПЦПИПЦПИПЦПИПЦПИПЦПИПЦПИПЦИПЦПИПЦПИПШШПШППШЇППП 


$пит1 = 8; 


$пит2 = 23; 


ООДО000000000000000000002-0000000000000000005.300 
ООО0О000000000000000000000000000000000000 


echo $num1 ; 


ПП 


есһо 8; 


О000080005пипл1Ц 


9.1.1 [ll 


ОООО0р00000000000000000000000000000000000000000 
ОО0000000000000О5сгіреа ph prid d$ namer mire e De i TEC] 
П0005сгірєВ.рһр00000%патеро000000000$%патер000јапеП 
ПО005сгірёА.рһр000000000000%пате000000000оса 0000 
ПОСООООСО000 


О000000000000000000%патеђ000000091ора 0000 
5СГІрЌА.рһр05сгірВ.рћр000$%патеО0000000000000000000 
ОО000000000000000000000000000000000000%патео00000 
ОООО000000000007000000 


5.1.2 ПІП 


О00000000000РНРО00000000000$чрегоіора 000000000 
ООООО0Д000000000000000000000000000000000000000000000 
0000 


° 5 СЕТИДОООЄЕТООДОООДОООО000000 

° $ РОЗТИДОДПРО5 ТПДОООДОДО0000000 

• 5 СООКІЕЛДДОсоокіе ПДДО000000000 

° 5 РІСЕЗОДООДООО ОДОДО00000000 

• $ ЗЕЕМЕВПООООООДОООДО00000000 

° 5 ЕМУГПППИПИПИППИПИПИППППИПИПИПП 

° $ ВЕОЗЕБТО ОДОСЕ TOPOS ТОСООКТЕДООООД0ОО0000000 
ПП 

9 ЗЕ551ІОМДОДОДОДО0Д0000000000 


ОО0О0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО000000000000ПРО5 ТОООООООООО0О0О00000000000000000 
ОО00000000 


5.2 [III 


ООООО0000000000000000000000000000000000000000000 
ООООО00000000000000000000000ОРНРОДОООООООО0000000000 
ОО000000000000000 


ОООО0000000000000000000000000000000000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
ОО000000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОО000000000 


05-1000ОРНРеДДОД8000000000 


05-1 [III 


EBEN ___ 
Ш 300808 
— m / 
sci 





КезоигсеГ ООООООО00О000000000000МУЗЕ0ОООДО00000000 
ШЕШИНЕ 


РАРОООООООООО000000000000000000000000000000000 
is *О000015_ босі 0 ПООООД00000000000005.100000000000000 


ППШПШШЦПППППП!ї5_ "ОООДООООООО0ОДО0000000000000 


00005.1 П00000000 


<?рһр 

$testing; // declare without assigning 

echo "is null? ".is null($testing); // checks if null 

echo "«br/»"; 

$testing - 5; 

echo "is an integer? ".is int(Stesting); // checks if integer 
echo "«br/»"; 

$testing = "five"; 

9: echo "is a string? ".is string($testing}; // checks if string 

10: echo "<br/>"; 

11: $testing = 5.024; 

12: echo "is a double? ".is double($testing); // checks if double 

13: echo "«br/»'; 

14: $testing = true; 

15: echo "is boolean? ".is bool($testing); // checks if boolean 

16: echo "<br/>"; 

17: $testing = array('apple', 'orange', 'pear'); 

18: echo "is an array? ".is array($testing); // checks if array 

19: echo "<br/>"; 

20: echo "is numeric? ".is numeric($testing); // checks if is numeric 
21: echo "«br/»"; 

22: echo "is a resource? ".is resource($testing); // checks if is a resource 
23: echo "«br/»"; 

24: echo "is an array? ".is array(S$testing); // checks if is an array 
25: echo "«рг/»"; 

26: 2» 


o N O) (л шо № — 


О000000000006еѕуре.рћроп00000000000000000%еөрп 
О00000000000%ебро00000000000000000000 


is null? 1 

is an integer? 1 
15 a string? 1 
is a double? 1 
is boolean? 1 

is an array? 1 
is numeric? 

is a resource? 
15 an array? 1 


000020000%еѕитопоо0о000000000000000300000000000 
0000000015 пе ПООД0001 (crue JL] 





ОООО0О00ОРНРОООООООДОООПОООООДОДОДООООО00000000000000000 


Notice: Undefined variable: testing in /path/to/testtype.php on line 3 


NOCOphp-development.inifggphp-production.iniQQ000000000000000000000 | 
000000 | 


000% testing ППИППППП--ППППП О testing ПОДООООООІЗ, У 
ПППППППППППЭППППППИПІ $ testing ПДрОДОДОДОООООД000000000 
О00000000000000000080000000000%еѕтороооо00000000 
ОООДО000000000000000000000000000000707090013410000000 
0000005фсе5іпа ПООДООООООООДО000000000000001400000000 
ПО ее5 тп ОДОДОД00000008гиебтатьеро 0000002 70] EE La rra y 0) 
ОООО000000000008000000000000000000ЗО00000000000000 
$testing[ "ОО" DOLI 


О020Д000000000000005се5іїпадд0000000200002200000 
тезі П9ДОДОДОДООООДОДОДОДОДОД00000000002400000 


фте5іїї ПОП ОДОДОДОДОДО0010 
5.2.1 ППѕеёуре() 000000000 


РНРОП0000ѕеёуре()000000000000000000000000000000 


ООО0О000000000000000000000000000000000 


settype($variabletochange, ‘new type'); 


00005.2003.1400000000000000000000!00000000 


00005.2 ПО05еёуре()000000000 


«?php 

$undecided = 3.14; 

echo "is ".$undecided." a double? ".is double($undecided)."<br/>"; // double 
settype($undecided, 'string'); 

echo "is ".$undecided." a string? ".is string($undecided)."<br/>"; // string 
settype($undecided, 'integer'); 

echo "is ".$undecided." an integer? ".is integer($undecided)."«br/»"; // 
integer 

settype($undecided, 'double'); 

echo "is ".S$undecided." a double? ".is double($undecided)."<br/>"; // double 


: settype($undecided, 'bool'); 
: echo "is ".$undecided." a boolean? ".is bool($undecided)."<br/>"; // boolean 
L 7 


ОДООД0О000000000015 "ОО00000000000000Оеспороб 


$undecided[ р ОД00000000006000007 3.14"000000000000000 
ОО000000000000000000000800000аочоіер0000$чпаесіаеа 
О0000030000001000000$чпаесіаеадрооо000000000000000 


ППШПЦШПЦЕгчеПППЦППРНРЦППШШШПШШгчеЦПЦПИ Рае 000 
[000000001100$упдесвеяч[ [11 


ООДО00000000 settype.php О00000000000000000 Webi 
О0000000000000%еюроо0000000000000000000 


is 3.14 а double? 1 
is 3.14 a string? 1 
1s 3 an integer? 1 
is 3 a double? 1 

15 1 a boolean? 1 


0000 


5.2.2 ППООООООООООООО 


П0ѕеуре()О0О000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООДОООО000000000000000000050гідіпаїматророр00000000 
ОООО00000000000005пемумагзфогіді паїмагрДор о О0000000000 
005 пемумат HIDE DID TTL 


$newvar = (integer) $originalvar 


00005.З0000000000000000000 


00005.3  ООД000000000 





<?рһр 

$undecided = 3.14; 

$holder = (double) $undecided; 

echo "is ".$holder." a double? ".is double($holder)."<br/>"; // double 
$holder = (string) $undecided; 

echo "is ".$holder." a string? ".is string(Sholder)."«br/»"; // string 
$holder = (integer) Sundecided; 

echo "is ".$holder." an integer? ".is integer($holder)."<br/>"; // integer 
$holder = (double) $undecided; 

19: echo "is ".$holder." a double? ".is double($holder)."<br/>"; // double 
11: $holder - (boolean) $undecided; 


12: echo "is ".$holder." a boolean? ".is bool($holder)."«br/»"; // boolean 


оо чо O bY N = 


13: echo "<ћг/>"; 
14: echo "original variable type ої $undecided: "; 
15: echo gettype($undecided); // double 

9» 


0000000 0Фзипае?сіагардддорорОрО0О00000Одомбіеллор 
1500000000000000009евеурерр000005 ипаесіагеа ППП 





ппореенуреопроровоароропоповорорововооропововопоповововоо 
ООД0000015 "ЗОООООО0000000000дебурерррро0000000 


00000005 и паесіаеадрооДрорДО0О0000000000000000000 
О0000000000000%һоіаег000000000000300000000050007 
О009000110000000000%чпаесіаеа000000000000 
Фипаесіаеа0000000000000005.20060$чпаесіаеа 100000 
ООО000000000000 


000005. 30000000000саз5ісуре.риродроооробОО 0000000 
\Ммеопо000000000000%еюооо00000000000000000000 


is 3.14 a double? 1 

is 3.14 a string? 1 

is 3 an integer? 1 

is 3.14 a double? 1 

is 1 a boolean? 1 

original variable type of 3.14: double 


О000000000005ѕеуре()00000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООРНРрООООООООООООВОООООООООООООоОооооооороооо00 0 
ООО0О000000000000000000000 


ОООО000000Н МЕОООООООО0О00000000070007 000000000 
ОООДОО0000000000000000000РНРОДОООООООО0000000 


"38cm" + "40cm" 


0000000700 


0000“ BIO О00000000000000000000000000000000000*3.14ст”0*4.12ст” 0L | 
00007.26000000000000000000000РНРО000000000000000000000000000000000 | 
0000000000000000000 “ 30спа"000"30"0000" 6ft2in” Q06 0000000000000000 __ 


ОООО0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000 


$test = "Зоест"; 


ООООО00000000000000000000000007 30 em [ШШШ 307000 
ООО0О000000000000000000000 


$newtest = (integer) $test; 
echo "Your imaginary box has a width of $newtest centimeters."; 


0000000 


Your imaginary box has a width of 30 centimeters. 


ОО00000000000000000000000000000000000000%еѕ00 
10$пемеѕП00000 


Your imaginary box has a width of 30cm centimeters. 


ОООО00000000000000000000000000000000000 


5.2.3 ШШШ 


ООООО0000000000000000000000000000000000000000000 
0000 7 О0ОО00000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОООД00000000000000000700700000000000000000000000000 
00000000 


5.3 ШШШ 


ООООО0000000000000000000000000000000000000000000 
ООО0000000000000000000000000000000П0регасог 0000000 
ОООО0000000000000000000000000000000000000000000000 
ООО000000000000000000000000000000000орегапад 


ОПООПООПОООООПОООООПОПООООООООПООПООПООПОООООПООООООООПОПОДОООО: 
ОО000000000000000000 x 


ООО00000000000000000000000000000000 


(4 * 5) 


ОО 05О00000000000000000000-00000000090000000000 
ООО0000000000000000000000000 


ООДО0000000000000000000000ОехргезвіопОПООО000000 
ООООО00000000000000000000000000ОРНРОДОООООД00000000 
О0000000006540000000005 ч5егГрД00000009Февєвєсурер 00000000 
ООО00004--50000000704707350700000007 + О0000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
ОО00000004- 5000090 


ОДООДО00000000000000000000РНРОДОДОООО00000 


5.3.1 (ІШІП 


ОООО000000000000000000000000000000000000000000 
ОО -ОООО000000000000000000000000 


$name = "Jimbo"; 


5 паттерОДОДОД00007 Jimbo О000000000000000000000000 
ОДО0000005 папердородродоб0бПООДООО0О00000000000000000 
ОО000000000000000 


echo $name = "Jimbo"; 


ОДО000000"7 лип бо” 00000“ Jimbo" T] Lj8namer Ti] 


5.3.2 ПШ 


ОООО0000000000000000000005-200000000000000000000 
ULL] 





о 


О III 
О О О О В 


5.3.3 [|H 
ОО000000000.0000000000000000000000000000000000 


"hello"." world" 


ПП 


"hello world" 


ОДОД0О00000000000000000000007"7 world" Im wort" 000 
ООО000000000000000000000000000000000000000000000000 
ОО000000000000 


"hello". "world" 


00000000 


"helloworld" 


ОООО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
00000000 


Фот = 212; 
echo "the width is ".($cm/100)." meters"; 


5.3.4 00000 


ОДООДОО00000000000РАРОДООООООООООО0ООО000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОоООрб00000000000000004000000000000004000000000000 


$х = 4; 
$х = $x + 4; // $х now equals 8 


IILI IILI LLL =I IILI IILI III I! 


$x = 4; 
$x += 4; // $х now equals 8 


ОООО0000000000000000000000005-З0000000000000000 
000000 


05-3 [HIHI 


, 
- i 


сор P= 


05-ЗООООООО0000000000%х00000000%х00000000000000 


$х = 4; 

фх += 4; // $x now equals 8 

фх += 4; // $х пом едџа15 12 
$x -= 3; // $x now equals 9 





ООО0О0000000000000000000000000000000000000000000 
ОДОООО00000000000000000000000Н МЕДОДО000000000000000 
0000000 


5.3.5 О000000000000 


ОРНРОДОООООООООООО0О0ОО000000100200000000000000 
ОО00000000000000000000000000000000000%х000 


$x = $x + 1; // $x is incremented by 1 


ОО000000000000 


$x += 1; // $х is incremented Бу 1 


ОООО00000000000Ф9х00000000000000000000РНРОООО0000 
[0000000000000000000000008 2000000000000000000000 
[]post-increment[ JL LLL ELIpost-decrement] 000000000000000 
[00000000000 


Фх++; // Зх is incremented Бу 1 


ОДО00000Ф9х0000000010000000000000000000000000 


$x--: // $x is decremented Бу 1 


ОООО0000000000000000000000000000000000000000000 
ПП 


$х = 3; 
фу = $х++ + 3; 


0000000$У00006(3 + 3)00$х0010 


ОООО0000000000000000000000000000000000010РНРОПО 
ПППППИрге-іпсгетелп ПП рге-аесгетеп ОООООООО0ООООО 
00000000000000000000000000000000000000 


++$х; // $x is incremented by 1 
--$x; // $x is decremented by 1 


ОООО000000000000000000020000000000000000000000 
00000%х00004000000010 


$x = 3; 
++$х < 4; // false 


орор0000гаїзедорьх по 0040040000400 


5.3.6 [|H 


ООООО000000000000000000000000000002счеоодро0000000 
ОДтатеПобДОДОО00000000000010м'берродроодорододорооророс 
О00060000м'плероб 


ОДО00009х0000000005000000000000000000000000000 


$х < 5 


ПП$хПЦППППЗППШПЦПШИПШПЦПЕГчеПЦПП$хХЦПППШП 7 ETBDIDEIDI BIET TL 


false] 


05-Ф000000000 


05-4 HIHI 





ор === [жер 
к= BE 
рше (е 
= = 


Ке RE 
| | RE 





ООО0О0О00000000000000000000000000000000000002:2000 
О0-000000000х2-е ПОДОД00000-00000000000002 20000000 
00000 


5.3.7 ПОДОООО0000000000 


ОО0000000000000000о)000000001)00000001000000000 
О00000000емерооро000ємгчер 


true || false 


ОООО гое 


ападо0000&00&&0000000000апапро0000000000 
гие 9 гое 


true && false 


LICIDEIDEIEIDIEIEIFa Is eC III IILI ип ППТ 
ОО00000000000000000 


($x > 2) && ($x < 15) 


LES хО000000200015000000006гмерордророброб000000000 
ОООДО00000000000000000005-9000000000 


05-5 ПШ 








ОД00000000гОапаордодододророорооорордророводроробо 
ОО000000000000 


5.3.8 [ШШШ 


ООООО0000000000000000ОРНРОДОООООООООО0О00000000000 
ОДОДООО000000000ОРНРеОООООООООО0ОО000000000000000 


4 + 5 


ОООООООООРНРрООАр50000000000000000000000 


о E 


ОООО000000ОРНРеДОДОДАО5О0000000002000128000000040 
о О02000000001400000000000000000000000000000000РНРГП 
ООООО0000000000000000000000000000000000000000000000 
оррр000405002000000 


ООО0О0000000000000000000000000000000000000000000 
ООО000000000000 


(4 + 5) * 2 


ОО0О0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 


ООО0О00000000000000000 


++, --, (cast) 


О00000000опг | | О0000000апарё&00000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ПП 


$х апа $у || 52 
$x && (Фу || $z) 


ООО000000000000000000 


$x and ($y ог $z) 
ООО00000000000 
ПООО000РНРО&&апароо000000000 | | Bert it ipm m Did ETT 


ООООО0Д000000000000000000000000000000000000000000000 
0000000000 | | O&& 0ОС0000000000000000000 


5.4 ||| 


ОО000000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000000000000 
[]constant[ ПППИПРНР Паеппео ООООД000000000000000000 
Дрр0000ОаейпеддрддООаейнеророропбооордбоборородородо 
ООО0000000000000 


define(" YOUR CONSTANT МАМЕ", 42); 


ООООО0Д000000000000000000000000000000000000000000 
ОООДО00000000000000000005.000000000000000 


00005.4 ОО0000000 


: <?php 

: define("THE YEAR", "2012"); 

: echo "It is the year ".THE YEAR; 
. 2> 


Oh = 


ОДОДОДОЗООО000000000000000000007 ® is the year" DIDI] 
ООРНРОДООООООООО000000000 


О00000000000Осоп5сапі. рирДобобОЗООООДОДОДОМУебООД 
ОО0000000000%№еопоо0000000000000000000 


It is the year 2012 


аеппе()О00000000000000000000000000000000000000000 
ПООО00000000&чеПО000аейпе()00000000000000000000000 
ПОООТАЕ_ХЕАКОООООООО 


define("THE YEAR", "2812", true); 


ОО0О0000000000000000000 


echo the year; 
echo ThE YeAr; 
echo THE YEAR; 


ОООЗО00000000000000000000000201 2)р00000000000000 
ООООО000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000000 


ООООДООРНРОООООООООО000000000 FILE ПОРАРООООООЦ 
ОООО000000 LINE ДОЗОДОООДО000000070000"  ОО00000000000 
ОООО00000000000000000000000000000000000 


http://www.php.net/manual/en/language.constants.predefin 
ed.php [] 


ППППППРНР_МЕКЫОМПЦППППРНРЦПШИШШШШ ШШ ШИШ 
ООООО0О00000000000000000000РНР.  МЕВ5ІОМ ООООДО00000 
ОО0О0000000000000000000000 


http://www.php.net/manual/en/reserved.constants.php [| 


9.9 ||| 


ООООООД000ОРНАРОООДОООООООООО0О0О0О00000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОО0О000000000000000000 


ОДОДОООРНРООООООООООООООООРНРеООООДООООО00000000 
ОО0О0000000000000000000000000 


5.6 Q&A 


ОбОООО000000000000000 
АООООДОООООО0ООО00000000000000000000000000000000 

ОООО0000000000000000000000000000000000000000000000 

ОРНРОДООД0О000000 

ОбОООО0000000000000 
АДОДО00000000900000005а6123245П0000000000000000 

ОООО0000000000000000000000000000000000000000000000 

О000000000%#0000000000000%#епатеро00000 


ОТПООО00000000000 


АООООДООООООО0ООО00000000000000000000000000000000 
ООО0О00000000000000000000000000 


5.7 HUUL 


ОООО00000000000000000000000000000000000000000 


HOLI 


1П000000000000000 


$a value submitted by a user 
$666666Xyz 

Фху2666666 

$ counter 

$the first 

$Tile-name 





2 ПООООООООООООО 
$num = 33; 


(boolean) $num; 
echo $num; 


ЗОДО000000000 


echo gettype( "4" }; 


АППШШШИШШИШП 
$test val = 5.5466; 


settype($test val, "integer"); 
echo $test val; 


ЗОООО00000000000000 


4; 
is int(44); 
5/12; 


бОООДЗО00000000000000 


ТОДОО0000000000 


ОО0000000000 


ИЦ 


11000%666666хуғП000000000000000000000%һће first m] 
ОДО0000000005 ПТе-паплеюдодОДО000000000000- 00 


2 ПОО000000033000000000005пипбо0О00000000000000 
ООО000000000000 


ЗООО0О000000007 string "T 
А0ООО00000500000000000000000000000000000000 
ЗОООО000000000000000 

60005/120000000000 


т9000000000таї'ероор00000 


ӨШ 


1П00000000000500000000000000000000000009еёуре() 
ОО0000000000000 


2 ПО0000000000000000000000000000000 


° ШШШ 

° ПП! 

° ПП! 

° ПООО000000 


ООО00000000000000 


ООО000000000000000000 


[6 РІНРОДОСОДО 


00000000 


ОДО00000000046маерсрооодиодоороо 

ПОД О000000000Фаї5ерродророоб00000 
000 EIS wireeh ПООДОООДОДО0О0000000 
П000аһНеро00000000 
ОД00РогО0000000 

0000000 

ОО000000000000000 
П000000000РНРрѕёаг епапоц 


ОО0О0000000000000000000000000000000000000000000 
ООО000000000000000000000000000000000000000000000000 
ООО000000000000000000000000000000000000000000000 


6.1 ПОГ 


ООООО0000000000000000000000000000ОРАРОДООО0---0 
ОДООД0О0О000000000000000000000РНРООООІОДО000000 


6.1.1 ШП 


ІТООООО0О000000000000000000000000000000000100000 
О000000----ОО000000009гчмероооорооброрД0000000000000000 
00000000 


if (expression) 1 
ff code to execute if the expression evaluates to true 


) 
ППИПИПИПИП happy "EIDEIDULD6 - 11010008 


00006.1 #0 


: <?php 

: Фтоод = "һарру"; 

: if ($mood == "ћарру") { 

echo "Hooray! I'm in а good mood!"; 


} 


2> 


O CO + Ó N — 


02000" happy 00009 пооаддозрор0000є 0005 moodul 
0000“ happy "ОДОООО0000000000002гиеророорорододооодО 
ОО0000005000 


б00000000без5ісірАРООДООООООДОДОУ/еьоо IILI IILI II 
Web ПОДООДОД000000000000 


Hooray! I'm in a good mood! 


LEID riSmoeoedTIDUD" saa" 000" happy  ПОДОДОООДОДОДОДОДО 
ТППППППППИПГТа!зеП ПП CD EID ПШПИЧИПППеізеі іі 


6.1.2 ||еісе(іІПІҢІП 


ОО00#000000000000000000000000000000ғаІѕероо00000 
О000000еїеррооД0ОО0000013О000000000000 


if (expression) 1 

// code to execute if the expression evaluates to true 
| else í 

// code to execute in all other cases 


} 


00006.200000006. 200000000005 ппооад)р000" happy” OLD 
0000000 


00006.2 Пбеїзедії)Л 


: «?php 
: $mood = "sad"; 
: if ($mood == "ћарру") í 
echo "Hooray! I'm in a good mood!"; 
| else í 
echo "I'm іп a $mood mood."; 


о м O) 0 + GON = 


: 
LLL О testifelse. ph p ПИПИНИНИНИНОМУе  ПОПИВОВОЙВ 
Д00УУевОДОДО0000000000000 


I'm in a sad mood, 


Д0000200Ф9ппо аб оод00000"заа"000000" Парру”ПШППЗЦП 
#00000О00О0Оғаіѕе0000000000000004000000еіѕе00000000000 
00000000 m in а sad поо0а ППП“сай ПППППФтооЯаППП 


ОД000100000еїерродорообоо0ооооо000000000000 
ейпег-оГДдОДОО0Д003000000000000000еї5еродооо00000000 
ОООО00000000000000000000000000 


6.1.3 [| j)]lelseif[| | ]ifl]] 


ПО00000000еѕеі 0000000000001. ..еіѕеғ...еіѕебо500000 
0001. ..еіѕе00 


if (expression) 1 
ff code to execute if the expression evaluates to true 
| elseif (another expression) í 
// code to execute if the previous expression failed 
ff and this one evaluates to true 
} else 4 
// code to execute in all other cases 
) 


О0000#1000000чеп000000000000еіѕеғ 00000000000 
ОДО000000000сгчерододроробдорбо00р00000етерооорооб0000000 
Д000еї5енй rr pp p p etse 0 


еіѕе ІІ Т ППеібе ТППППППППППППППППППРЕАВГРНР extension and 
application repository ПРНРОДООДОДОРЕСІПРНР extension community library[] 


РНРППИПИПИПИПИПИППГПе!бетг | 


00006.30000000000єі5еї 00 


00006.3 ППезеПезе и О 


«?php 
$mood = "sad"; 
if (Фтоод == "ћарру") { 


echo "Hooray! I'm іп a good mood!"; 
) elseif ($mood -- "sad") ( 
echo "Awww. Don't be down!"; 


— (O со ч O OQ + 0 — 


) else í 
echo "I'm neither happy nor sad, but $mood."; 
} 
Q: ?> 


О$тооа00000" ѕаа” 020000000000" happy” "О0000004 
О00000000500еіѕе 0005 mood LITE)" sad 0000000000000 
єгоеП000006000000070009000000000000000000000000 
Га! еп ОДОД00Д0000000000000000000000000005 me e d 0000 
ПП 


ПОПОВОВО О testifelseif. ph p LIU DD OD UO UO E We br IILI I I 
О0000%Уеюро00000000000000000 


Awww. Don t be down! 


ПФтпооаГ ТГ ty "ОООДОДОДООО000000 


I'm neither happy nor sad, but iffy. 


6.1.4 switch|J| 


5миї С ПОДООДОООДОДОДб0О0000000000000000001й0еїзеїі 0 
ПППППППИППИПППәу/ С А LI LIL ПП ППТ ПП 
ППППТПППППИПИПППГППІГ Ieru e TELF Is e DE] w ree в ДОДОДОДОДО000 
ООО00000000000000 


switch (expression) 4 

case resulti: 
// execute this if expression results in resulti 
break; 

case resulta: 
[1 execute this if expression results in result2 
break; 

default: 
// execute this if no break statement 
// has been encountered hitherto 


5м'СПОООООДО0О000000000009 пооадП5мієспорСООЗОДОООО 


ОДОО00000000000000О5мм'есвОДОООООДООООООДОДО000000000 
О000000000бгеакддоОвмлеспОДО0000 


ПОПЫ rea кДДОДОООДООО0О000000000000000000000000 


ОООО000000000000000000000000000000 


= (O 
O -- 


11: 





О00000000000000000000000000геако000000000000геа коо 
ОООД00000000000000000000000000000000000000000000 


1 
2 
3 
4: 
5% 
6: 
fi 
8: 


00006.4)О5млеспДОООДОДІТОДОДОДО0 


00006.4 | switch[][] 


: <?php 
: $mood = "sad"; 
: switch ($mood) { 


case "happy": 
echo "Hooray! I'm in a good mood!"; 
break; 
case "sad": 
echo "Awww. Don't be down!"; 
break; 
default: 
echo "I'm neither happy пог sad, but $mood."; 
break; 


:) 


Ae > 


ПП2ППФтоод 0000007  5аа"Д030О5мимієсп m jp p ep i TETTE] 


ПППАПППШШШШШШЦШ happy "ЏО mee d ООО0Д0Д000000000000 
ОДОДО000/7О00000000000007/ 5ад"0ФппооабрДоОПО0ОО0000000000 


9LribreakD 00000000200001 2000000000000000000000000 
стер 00 


Д000000000Обезбмиєсп. риРрОДОДОООООДОДОМУевО0ОООДОО 
ОД00УУеророородододороро 000 


Awww. Don t be down! 


[]&mood[]LDU happy” ПОДОДОДО0000000 


Hooray! I'm in a good mood! 


О0006бгеакороодродор00р0000006бгеакород00000005 mood] 
0000" sad" рДО000000000 


Awww. Don't be down!I'm neither happy пог sad, but saq. 


ОДОО0О0000000000000000000006геако0О 


6.1.5 [DUE 


EEEHEEEBHEEEEEEEESEEEEEEEEEEEEEEEEESEEEEEEEENEN 
ООООО0000000000000000000000000000000000000000000000 
ПП 


(expression) ? returned if expression is true : returned if expression is false; 


ООО000000096гчеророорбопорор00О00000000000000006.5ПП 
ОД000005 пооаддрродо0000 


00006.5 [HIHI 


1: <?рһр 

2: $mood = "sad"; 

3: $text = ($mood == "happy") 2 "I am in a good mood!" : "I am in a $mood 
mood. " ; 

4: echo "$text"; 

э T> 


ПП2ЦППШ$тооаЦП“5аа”ПЦП3ЗПШШШ$тооаЦППШП“ happy” UUD 
ППШПШПЦПТа!5еПППШИПШПШИШИШШИПИШШИИИШП 


ПИПШПЦШПЦЦКе5Кеп.рһрППШПШШИШИШИШИИЦП\/еРЦППШШПШШИШШШП 
\меопо0000000000000000 


І ат іп a sad mood. 


ООО0О000000000000000000000000000000000000000 


6.2 [|| 


ОООО0000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ПП 


6.2.1 while] 


ммА!ероо00000000:#1000000000000000 


while (expression) { 
ff do something 


j 


ОН ОДр00Ом he LIL LI L чей [IILI IILI LIL ILI LII IL 
ОДОД0О0000000000000ї/сегабопДООО0000000000000мпИероо0 


ООООО0000000000000000000000000000000000000000000000 
6.60000м плеррурододгоророг40 


00006.6 — while[][] 


: <?php 

: $counter - 1; 

: while ($counter <= 12) { 

echo $counter." times 2 is ".($counter * 2)."<br /»"; 
$countertt; 


} 


2> 


NOOR ого = 


ПШШПШШЦП2ППШШШП$соипїегЦПШШШШПШИПЗПЦМУ hie ПІ 
$counter[] I] ]$counter[ 0000002 200000000000мблтерооо00 
ЦОфсоипеегддО0200000000000000005005 eeunter 00000 LET] 
ПШШПШШЦШИПШШЦИШПЦП$соипїегЦПЦм піердррододроОтатьероо000 
ULL] 


LLL О testwhile. ph p TETEYDIEIDEI DO UO We bETDEIDIDII ШЕП 
О0ммерборорородоводроророро0 


1 times 2 is 2 
2 times 2 is 4 
3 times 2 is 6 
4 times 2 is 8 
5 times 2 is 10 
6 times 2 is 12 
/ times 2 is 14 


8 times 2 is 16 
9 times 2 is 18 
18 times 2 is 20 
11 times 2 is 22 
12 times 2 is 24 


6.2.2 do...while[|l| 


до... леППППППЦПЦПМУ Ие ПП ПП ПП 
ао... мПИердроОдбООДОДООДОООДОДООДОООДОДО00000000 


do í 
/{ code to be executed 
} while (expression); 


ОДОД000000000000000мбердрдодрОтатверорр00Оао... 
мУПИерО0000000006.700000ао0.. моітерродророродрдодоо 


00006.7 —do...while[][] 


: <?php 


1 
2: $num = 1; 

3: do ( 

4: echo "The number is: ".$num."«br /»"; 
5i $пит++; 

6: ) while (($пит > 200) && ($num < 400)); 
Гі d 


до. ..лмћ!ер000%пчтр0000000020000040010000200000 
5 пипООДОЗ000000000000ТаїерооДобОбо0б000000000000000 
до... мППедрдроОбОЗОДОДОД000 


О000000000бе5сдом'піте.риРодДоДоДОДОДОДОМУеОрородрО 
ОД00УУерородоророоророрео 00 


The number 15: 1 


Ор002009Ф9пипаррд0О0зО090О0000000000000000 


The number is: 300 


ОО0О000000000000000000000 


The number 15; 399 


6.2.3 Тог |] 


ОрРог 0Д000000000ОмвтеродоробоРогороброборороороПО 
О000000006.60000000000мвтердододбор00р00000минеродрооо0 
ОД0000000000огорООбОДООО0000О00000000000000000000 
ООО0О000000000000000000000000000000 


for (initialization expression; test expression; modification expression) 1 
ff code to be executed 


ООООД0О000000000000000000000000000000000000000000У/е60000000000 ) 
О0000000000 x 


тогПООО0Д000000000000000000000000000000000000000 
ОО0000000000000000000000006.8000000000006.600000ғ 
О00000000200120000 


00006.8 дОбогб) 


: «?php 
: Тог ($counter-1; $counter<=12; $countert++) 1 
echo $counter." times 2 is ".($counter * 2)."<рг /»"; 


} 


?> 


л T+ O о — 


О000000000безібог. ph рОДООООООО0О0ОУУеБОПОООО0ОО00000 
Web ПООДООДОО00000000000 


і times 2 15 2 

2 times 2 is 4 

3 times 2 is 6 

4 times 2 is 8 

5 times 2 is 10 
6 times 2 is 12 
7 times 2 is 14 
8 times 2 is 16 
9 times 2 is 18 
10 times 2 is 20 
11 times 2 is 22 
12 times 2 is 24 


00006.606.80000000000Р0Г000000106.800000000000000 
ОД000005 соипеегорроодоЗОДООООДОД00000002000000000000 
ППФсомпгег 00000 LEIDULIDIIEI HS counter 00000000 E 20000000 
00000%соипїёег00000000000000000000000000 


О000000000#юг000000%соипёего000000000000000000 
єгиеВ00000000000%соипёегО0000000000000000000000000 
Wooo false] 


6.2.4 Пргеак 0000 


мУпеддОРогоДООДО000000000000000000006бгеакорор0000 
ОДОД0О00000000000000000000000000006.000000007070000 
ОООО0000000000000000000000 


00006.9 П00010000040001ғогр 


: «?php 

: Тог (Фсоиптег-1; $counter <= 10; $соиптег++) í 

$temp = 4000/$counter; 

echo "4000 divided by ".$counter." is...".$temp."<br /»"; 


ос + шом = 


} 


2> 


ОО2Г0000000005 сом пеегр00001 Рог EE p LIL IL 
эсоипгег ОДО001000000004000П05 сочпіегДОО000000000 


О000000000безібог2. рпРродоД000000000У/ебОДОООСОЗОЦО 
[Web ДОООДОДО00000000000 


4000 divided by 1 is... 4000 
4000 divided by 2 is... 2000 
4000 divided by 3 is... 1333.33333333 
4000 divided by 4 is... 1000 
4000 divided by 5 is... 800 
4000 divided by 6 is... 666.666666667 
4000 divided by 7 is... 571.428571429 
4000 divided by 8 is... 500 
4000 divided by 9 is... 444.444444444 
4000 divided by 10 is... 400 


О00000000000000000%соипёегоо50000000000000000000 
ОДООО0О000000000000000000000000005 соипеег) 0001000 
– АПОО500000000004000000000000000000000000000000000 
000000000“ опаеппеа”000%соипёегО000000006.1000000 
ОО0000000000 


00006.10  []]]break[][] 


1: «?php 

2: $counter = -4; 

3: Тог (; $counter <= 10; $counter-*) í 
4: if ($counter == 0) í 

5: break; 

6: ) else ( 

T $temp = 4000/$counter; 

8: echo "4000 divided by ".$counter." is...".$temp."«br /»"; 
9: ] 

10: } 

11 7» 


ОРНРООООООООО0О00000000000РНРОДОВОДОДОДОП 

ОД4ОДОО0ОО0000ЙОДООО000000000000000005сойпеегПО 
10$соипёег10000006геакоо0000000000000000ғг00011100 
0000000 


б000000000безібог3.рпродоД000000000У/еборОООСОЗОЦО 
[Web ПП ППТ 


4000 divided by -4 is... -1000 
4000 divided by -3 is... -1333.33333333 
4000 divided by -2 is... -2000 
4000 divided by -1 is... -4000 


000005 counter 0 200000000 тог ооооообоооовоооовоооо 
[IL I$counter[I II IILI III 


6.2.5 Псопшпие ПОП 


сопіїпие ДО ОДОДО0Д000000000000000000000000000000 
06.10)д00бгеа крр00000000000к6.11)00Осопііпчеророро00000 
ОО0О0000900000 


00006.11  [][]continue[][] 


«?php 
$counter = -4; 
for (; $counter <= 10; $counter+t+) í 
if ($counter == 0) í 
continue; 
} 
$temp = 4000/$counter; 
echo "4000 divided by ".$ counter." is...".$temp."«br /»"; 


— о о чо (л + O + 


со 
~, 
V 


УПО ricentinuer TED break ibis сочи ег ПОПоПИГ 
ОО0000000000000 


О000000000Обезісопііпие.рирДОДОД0000О0ДО0УУеБДООД0О000 
ОД000У/евородрооодорбороодДод 


4000 divided by -4 is... -1000 
4000 divided by -3 is... -1333.33333333 
4000 divided by -2 is... -2000 
4000 divided by -1 is... -4000 
4000 divided by 
4000 divided by 
4000 divided by 
4000 divided by is... 1000 
4000 divided by is... 800 


1 is... 4000 
2 
3 
4 
5 

4000 divided by 6 is... 666.666666667 
7 
8 
9 
1 


15... 2000 
15... 1333.33333333 


4000 divided by is... 571.428571429 
4000 divided by is... 500 

4000 divided by is... 444.44444444444 
4000 divided by 10 is... 400 


ОДДбгеакОсопіїпчеррорДоДООО00000000000000000000000000000000000000 x 
ОООД000000000000000000000000000000000000000000 x 


ОООД0000000000000000000000000000н 7МЕДОО0000000 
О00000000006.120000Ро0гОООО00000000000 


00006.12 ПП00ғог0 





1: <?php 
2: echo "<table style=\"border: 1px solid #0800; 1"> Xin"; 
3: for ($y=1; $y<=12; $y++) ( 
4: echo “<tr> An"; 
5: for ($x=1; $x<=12; $x++) í 
6 echo "<td style=\"border: 1px solid #090; width: 25px; 
7 text-align:center;\">"; 
echo ($x * $y); 
9: echo "</td> Ап”; 


113 echo "</tr> An"; 


} 
13: echo "</table>"; 
14: 7» 


Др горОД0000000000006.12000200 


echo "<table style="border; 1px solid black;\"> An"; 


ОДООДО00000000000000000000000000000.000000000000 
6000 "ОДПООООООО000000000000000000РНРОДООООДОД00000000 
ООРНРОДООЗОООООООО000О0О00000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОДООДО0000000000ч90000000000000000000000000000 


О00РогОДООЗОДОДООО О0ФзУОДООООО000О020000Р00000000 
ООО5УПОД00001 200000000000000000000000000000000060000 
OOOOH тмеДуроФгорроро0Рогор0О 05 00000000000000005х0000 
ООО000000000000000000000000000еа0000000000000006000 
7000000%х00$УБОО0080000090000000000000000000000000 


ООО0000003 2 0рД000000000000000000000000000000000000 
00000002 ЗОДОООО0000000000000 


О000000000безіпезіїог ph роОДД0С0С000000УУЕБОДОДОДОП 
ПОБЕАА/е оро00000000000006-1000000 





[=] localhost/06/testnestfor.ph 


< Q ©) http://localhost/06/testnestfor.php а 


В Е Ба 
2 as p o па e [16 [s [222 [2 
ре ЕЈ aas is [21 [2« [27 30 з 6] 
а a [as [20 [2s [28 2 [36 ао аа [ав] 
Cs [ios [20 2s [30 3s о 4s [so] [8 
Ee | а ву а so [se a [as | 5: [o s 72] 


Cr Tie [2s [3s [2 9 56] 6] 70 77 [а] 
Cs [1e [2s [32 [ao [es [56] ва |72 во ss [os] 
C [us 27 [3e [s [ss [s [72 81 [so] vo [ros 
10| 20 зо [4 | зо] 60 | 70] о [вооа 
Cu [aa s [| ss [es [77 ва [эз [nora o 
Ca [2s 5s 48| во] 72 [а [os [noe ao sana 





06-1 testnestfor.php[]LL] 


6.3 ПИШ 


ООФОД00000000ОРНРОДОООООООО0О0НИ МЕДДООООООД0000000 
ОДіОвмиєєвОДОДОООДОДООДО0ООДОДО0Д000000000000000000 
ПП 


LLIILILILILILILILILILILILIILI L Litruel IU ILILILILILILILILILILILILI6.131I II) 
ПИППППППППИПИППИПНТМЕІЛІІ 


1: <?рһр 


00006.13  Пб0беслоцррооо 


2: $display prices = true; 
3: if ($display prices) ( 


4: echo 
5 echo 
6: echo 
T: echo 
5: есһо 
9: есһо 
19: ) 

11: 7» 


"<table Богаег=\"1\">\п"; 

"<tr><td colspan=\"3\">"; 

"today's prices in dollars"; 

"</td></tr>"; 
"<tr><td>\$14.00</td><td>\$32.00</td><td>\$71.00</td></tr>\n"; 
"</table>"; 


ОДОО080000000000000000000000000000000000000000000000000000000 ° 
$display | ргісезор002000атмедоДО000000000000000000000еспоб бДр00000000 
ОДООО0О000000Н TMLOOOOOL 


О000000000без5іппиніеспо. риРОДОДОДОДОДОДОМУебОООДОП 
ОД0000УУеБСООООО00000000006-2000000 


[2] localhost/06/testmultiecho. х \ = 


= С | © http://localhost/06/testmultiecho.php ~ | 





06-2 (езшти есћо.рћроро 


ОДООДО000000000000000000Нн 7МЕОООО00000000000000 
06.140000000000 


00006.14 ПППППИПНТМЫП 


: <?php 

: $display prices = true; 

: if ($display prices) í 

2» 

: «table border-"1"» 

: <tr><td colspan="3">today's prices in dollars</td></tr> 
: «tr»«td»5$14.00«/td»«td»$32.00«/td»«td»$71.00«/td»«/tr» 
: «/table» 

: <трпр 

10: ] 

11: 2» 


(O o — O) (л + OMN ~ 


ОДОО0О000000000300000000000000040000Н 1М2000000 
О000000000000000есһо()0000000000000000000000000000 


ОО0000000000000000 
6.4 || 


ОООО0000000000000000000000000000000000000000000 
ОО00000000000 


ОДО000000н0000000еФї5еї)етероооДОДОО0000000000000 
ОДОО0000000000000000О5мм'еспОДОООООООб0О0000000000000 
мУпЛеро ГДДОДОДД00000бгеаксопііпчердроДоДО00000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОРНРОДОООДОООООООО0ОО00000000000000000000000000000 
0000000 


ОООО0000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000000000 


6.5 О&А 


ОбОООО00000000000000000 


АООООДОООООООО0ОО00000000000000000000000000000 
татвердорд00000008гиеб 


ОбОООООО0000000000000000 


АООООДООООООО0ООО00000000000000000000000000000000 
ОООО000000000000000000000000000000000 


6.6 (ПІ 


ООО0ОО00000000000000000000000000000000000000 


ЦИН 


1000000000Фадеб)0180350000000003О00000000000 
П“ Youth message"[][][]$ageL]HLDLHLILILILILHEHTL]" Generic 
message T] IL LIL IILI, 


2)00000Фадеро102 "ОДОДОООООО010О000000007 Chila 


message [| 
3LLII I LI1L149[ I IL LILI I LIwhilell[|i[] 


а4000000300000мптерроодрор0Ропг000 


ИЦ 


1. 


$аде = 22; 


if ((Фаде >= 18) && ($age <= 35)) ( 
echo "Youth message"; 

) else 1 
echo "Generic message"; 


} 


2. 

Gage = 12; 

if (($age >= 18) 44 (Sage <= 35)) í 
echo "Youth message"; 

} elseif (($age >= 1) && ($age <= 17)) (í 
echo "Child message"; 

) else ( 


echo "Generic message"; 
| 


3. 
$num = 1; 
while ($num <= 49) ( 
echo $num."«br у>": 


$num += 2; 


) 
4. 


for {$num = 1; $num <= 49; $num += 2) { 
echo $num."«br у>": 


} 


ӨШ 


О О О О О О 
ОООДО000000000000000000000н17МмЕ000 


2 ВО000000000000000000000000000000000000 


1711 0000 


ОО00000000 


ОО000000000000 
ООО000000000000000000 
ООО0000000000000000000000000 
ОО00000000000 

О000000"007"0 
ОО0000000000000 
ОО0000000000000 


ОО0О0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОО000000000000 ШШ 


7.1. ПІПІП 


ОООДО000000000/ ООО0000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ООО00000000000000 


ООООО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО0О000000000000000000000000000000000 


ПШ псбіопоДООДООООООО0О00О0000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО0О00000000000000000000000000000000000 


7.2 000 


ОООДО00000000000000000000ОРНРОДООООООО0О0000000000 
ОО000000000 


strtoupper("Hello Мер!" }; 


00000005ёгоџррег()0000000"НеПо Web!” 00000000000 
ООООО00000000000000000000000000000000005ігссиррегіПП 
ООООО0Д000000000000000000000000000000000000000000000 
П Шагаитеп ОООДООООД00000000000000000000000 


some function($an argument, $another argument); 


ѕігёоиррег()О000000000000000000000000000000000000 
ОО00000000000000000000000005$%оџррег()00000000000000 
ООО0000000000000000000000000 


$new string = strtoupper("Hello Web!"}; 


ОД000000000005пему string ДОООООДО000 


echo $new string; 


ООО00000000000000000 


HELLO WEB! 


ргіпє)Оесһо()О0000000000000000000000000000000000000000РНРО0000000 | 
DOBDODOhttp://www.php.net/print []http://www.php.net/echo 0000000000000000 | 
[000000000000000000 x 


П00аюѕ()00000000000000000000000000000000000000 
7.1000000 


00007.1 О0000а6ѕ5()00 


1: <?рһр 

2: $num = -321; 

3: $newnum = abs($num); 
4: echo $newnum; 

5: //prints "321" 

6: 7» 


О00000000000- 3210000005пмпор0000090000000а6500 
ООДОДО000000000000000000000000005 ne wnu m ДООО0000 


EICIBCOIDUDUDUUI а bs. олроооооообобобобомеопооооообоц 
LUE Web р ОДОО00000000000000000 


321 


ОророровороброВороороророророПабвє ООООО0000000 


echo abs(-321); 


ООООО0000000005 пуп 0$ пемипипА ДОДОООООООО0000000 
ООО0О00000000000000000000000000000000 


ООО0О000000000000000000000000000 


7.3 ОООООЦ 


ОД0000ипсбопдОрО0000000 


function some Tunction($argumenti, $argument2) 


//function code here 


} 


ОД00000ч псбопородДодоООбООПООДО0О00О0000000000000 
ООООО0000000000000000000000000000000000000000000000 
ULL] 





0000000000005 0000000000000000000000000000000000000000000000000: 
ОО00000000000000000000000000000000000000000000000000туғипсіоп()0 x 
папаіе5отерісиіТаѕк()00000000000000000000000000000000000000000000 | 
ОО0000000000000 x 


00007.200000000000 


00007.2 — 000000000 


: «?ph 
: function bighello() 


{ 
echo "<h1>HELLO!</h1>"; 


"Oo тор ог» = 


} 
: bighello(); 
25 


0000 7 .2000000000000Н TM Lh TETTE IECIT НЕКО У Ц 


ООДО00000000 bighello.php ВП000000000000000 Web uu 
ОДО0000000УУерооодОДО00000000000/-2000000 





ГЕ localhost/07/bighello.php 


€ С! О http://localhost/07/bighello.php 3, 


HELLO! 


П7-1 bighello.php|[ ПП 


000007.200000000000бідпейо O ООб00000000000000000 
UOUUbighello ОДООООООО0000000000000007.30000000000000 
ОО0О0000000000000000 


00007.3 — 00000000000 


: «?php 
: function printBR($txt) 


echo $txt. "<br/>"; 


: printBR("This is а line."); 

: printBR("This is a new line."); 

: printBR("This is yet another line."); 
2> 


о o ы O О „о N — 


ООООО00000000000000000000Оргіпев R ООДО0000ргіпіогоПРВІМ ТВА п 
ОО00000000000000 | 


ОДОДО00000000рпіпібг. рпРрОДОСОДОДООООООДОПУУевОДОО 
О0000000%еБоо0000000000000000007-2000000 





localhost/0//printbr.php 


€ С О http://localhost/07/printbr.php a, 





07-2 ООДОД0000000000« bn 2 00000 


ППӘППргіп ВК ООООООДО0ООДО000О00000000000000000000 
LCD S extr iid printB в ООДОО000000ФЕх00000000000000300 
00000%х1000000000<0г/> 000 


ОО0000000000000000000050006000700000000рипвк() 
ПППППргіп eO Д000000000х br» 00000 


7.4 ШШШ 


ОДОД0О000000ргіпєвв ОООДООбОД000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО000000000000000000000000000пмгесигоДООО0000000000 
УОгесиго ПОООООДО0000000000000000000 


0000/.Ф00000000000000000 


00007.4 — 00000000 


: <?ph 
: function addNums($firstnum, $secondnum) 
( 
$result = $firstnum + $secondnum; 
return $result; 


} 
: echo аааМит5 (3,5); 
: //will print "8" 


. 2> 


оо + O) O + O N ~ 


Др0р00000000Оадапипл5. ph РОДОООООООООООООООУУеБОСО 
ОДОД000000УУеродорообо0ор0О ороророрО 


8 


00000200ааамитѕ()000000000000000000000006000000 
О000030500000000%гѕіпит$ѕесопапит0000000000 
ааамитѕ()0000000000000000000000000%геѕи 0000 


гетигоОПОО000000000000000000000гесипгорОДО0000000000 
ОЗ000000000 


return 4; 


ОО00000000000000000 


return $a/$b; 


ОООО0000000000000000000 


return another Tunction($an argument); 


7.5 00000 


ООО0ОО0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000 


0000. З00000000000000000000000000000 


00007.5 ПОО000000000000000000000000 


: <?php 
: function test() 


$testvariable = "this is a test variable"; 


: echo "test variable: ".$testvariable."<br/>"; 


"Oo QI + WD + 


О000000000005сорегезі. риродоДоДОДОДОДОДОДПУ/еоОО 
ОДО0000000УУебродоододОО00000000000/-з000000 





[5] localhost/ü7/scopetest.php 


om С! © http://localhost/07/scopetest.php A, 


lable: testvariable m C:\xampp\htdocs\07\scopetest.php 





П7-3 scopetest.php UU 





ООДОДОДО0000РАРООООДОООО00000000000007-3000" побісе" 0000000" test. 
магіабіе”ПООООВО0000000 | 


[]|]$testvariableD i iibi in ев eO D II LI LI E T LI LI 
ОЗООО0000000000000РАРООООООООДООООООО00000000000000 
7-ЗОООО0О00000000000000000000000007 test магіабіе:"П 


ОО0О000000000000000000000 


Пре! оба 10000 


ООООО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000/7.60000000 


00007.6 ОООООДОООДОДОДО0О00000000 


: «?php 

: $life = 42; 

: function meaningOfLife() 
{ 


echo "The meaning of life is ".$life"; 


очо ол + ОО N — 


} 
: meaningOfLife(); 
> 


О000000000005сорегезі2.рпрОДОДОДОО0О0О0О0000УУебОГ 
О0000000000%еооо000000000000000007-4000000 





/ localhost/07/scopetest2.ph, x \ > 


< Q ©) http;//localhost/07/scopetest2.php A, 





Notice: U; raeme oO 
4 
The meaning of Ше 15 


variable: Ше m C:\xampp\htdocs\07\scopetest2.php on line 


07-4 ЮДОДО0Д000000000000 


00000000Опеапіпдойпед)удод0000200005Пптеррорордоод 
05 пгеророОоододордоодорбороодорбодооддорбободороо 
ООООО0000000000000000000000000000000000000000000000 


ОДООО00000000000000000009106а ІООО0000000007. 7009! ова! | 
00000000 


00007." Дбдіобат р 00000 


: <?php 
: $life-42; 
: function meaningOfLife() 
1 
global $life; 
echo "The meaning of life is ".$life"; 


(O O + O CO + O N ~ 


} 
: meaningOfLife(); 
75 


О000000000005сорегезі З.рп рОДОДОДОДОДОДОДОДОУУевог 
ОО0000000000%еооо000000000000000007-5000000 





и | = | [=] в : | 
localhost/07/scopetests. ph 
E Q ©) http;//localhost/07/scopetest3.php ~ | 
The meanmg of Ше 15 42 


07-5 ОДООД000091о06 а Д000000000000 


ПШШПтеаптдОТТе()ППЦППП$!!ТеПЦППШШПЦППАППИЦШПӘ!оБа![П 
ОДб0О00000000000000002000005 икерооооооооовоооовоооц 
ОД00000009106а 00000000000000000000000000000000000ц 
00000000 


Орр000а1обатрророДрроо0орбобоОоороропбрдододророрзо 00 


global $уаг1‚ $var2, $var3; 


ОПООПООПОООООООООООПОПОООООПООПООПООПООПОООООПОбОООПОООООООООДО 
ОООО000000000000000000009106а ІОДОООО00000 u 


7.6 [| listatic[|] III 


ООООО0000000000000000000000000000000000000000000 
00000 


ООООО0000000000000000000000000000000000000000000 
ОДОДО0О000000000000000091065а100000000000007.8000 


00007.8 0оіора0000000000000000 


со ч O Оол + O N ~ 


«?php 
$num of calls - 0; 
function numberedHeading($txt) 
i 
global $num of calls; 
$num of са115++; 
echo "«hi»".$num of calls." ".$txt."</hi>"; 


} 
numberedHeading(" Widgets"); 


: echo "<p>We build a fine range of widgets.</p>"; 
: numberedHeading('Doodads"); 

: echo "<p>Finest in the мог1а. </р>"; 

: 2> 


ОО0000000000пупбегеапеаадїпд. рирОоДОСОДОО00000000 


Учеб ПООДО0Д000000УУеорооодДОО00000000000007-6000000 





1 Widgets 


We build a fine range of widgets. 


2 Doodads 


Finest m the world. 


07-6 ППоіора DO CHO III! 


П00000000питрегеаНеааіто()00000000200000000 


$num ої са!$П005000009іора00000000000000 


ПОООичтбегеяаНеа9тоа()]$пит_о{_са|$00]00001:0006 
ПООДООДООД000000000000000000000 


О0000000000000000091іора00000000000000000000000 
ОООО000000000000000000000 


0000005 а зєОО000000000000000005 са en 0000000000 
DEIEIBBICIEY CIE ETE DICIT ACIE TEE TETDE IEEE ACIE TLIC IE DEI ПП 0000000000 
7.90000000/7.800000000О5саєіс000 


О0007.9 ППәканс ОПОДООООООООД0000 


«?php 
function numberedHeading($txt) 
{ 
static $num of calls = 0; 
$num of са115++; 
echo "<hi>".$num of calls." ". $txt."«/h1»"; 
} 
numberedHeading("Widgets"); 
9: echo "<p>We build a fine range of widgets.«/p»"; 
19: numberedHeading("Doodads"); 
: echo "<p>Finest in the world.</p>"; 
: 7» 


со) зоо O + an = 


— — 
№ — 


питрегеанеааіто()00000000000000004000 
$num of са!$ПООСО0000000000000000800000000000000000 
ООО000020р00000000000000000000000000000 
$num ої сай ПП питрегеанеасйтад ПД0О00000000 
000000000000000000007.900000000007.800000000000000 


7.7 БООО00000 


ООООО0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОО000000000 


7.7.1. 00000000 


РАРОООООООООООООО000О000000000000000000000000000 
ООО0ОО0Д000000000000000000000000 


00007.10б00000000000000000000000Н T МЕ spa nrTHOUBUL 
ОДД00000000000бопо-5іге рДДОД00000000000000000000 
$fontsize[]H 2L JI |[ ] 


00007.10 ДОООДО000000 


<?рһр 
function fontWrap($txt, $fontsize) 
{ 


echo "<span style=\"font-size:$fontsize\">".$txt. "</span>"; 


} 

fontWrap("A Headingsbr/»","24pt"); 

fontWrap( "some body text<br/>","16pt"); 
fontWrap("smaller body text«br/»","12pt"); 
fontWrap ("even smaller body text«br/»","10pt"); 
: ТР 


— о со + O Ол + O N ~ 


со 


ООДО00000000бо0пім/гар.Р'РООООООООООДОДОДОПУУебьсСОГ 
ОДОД000000УУевродрододбОбО0 00000000 7 - 7000000 





! [5] localhost/0//fontwrap.php 


€ CQ © http://localhost/07/fontwrap.php ~ | 


A Heading 
some body text 
smaller body text 

even smaller body text 


17-7 ОООО00000000000 


ОДОД0О000000000000000000000005то0п5ігерродр000000 
ОДООДО000000000000000000000000000000000000/ 12000000 
О005Топсзіге р ОДО000 


00007.11 ДБОДО0000000 


1: <?php 
2: function fontWrap($txt, $fontsize = "12pt") 
Я 


{ 
4: echo "<span style=\'"font-size:$fontsize\">".$txt. "</span>"; 
} 
fontWrap("A Heading<br/>","24pt"); 
fontWrap("some body text«br/»"); 
fontWrap("smaller body text<br/>") ; 
fontWrap("even smaller body text<br/>"); 
0: 2» 


= (O @ чо о сл 


О00000000ғопёМғар()О00000006000002000000008ѕраһпд0 
Огопі-5ігеПООДОДО0Д00000000/70008000900000000007 12 p €] 


ОООО0000000000000000000000000000000000000000000000 


7.7.2 [JII 


ООООО0000000000000000000000000000000000000000000 
ООДО0000000000000000000007.220000 


00007.12 ОДОДОДОДОДО000 


: <?php 
: function addFive($num) 


( 
} 


: $orignum = 19; 
: addFive(S$orignum); 
: echo $orignum; 

2> 


$num += 5; 


о со ч O) GI осо) N = 


ППШПШШШШШШШПааайуме.рһрППШПШШШШПШИПШШПШШП Web 000 
О000000000%еБро000000000000000000000 


12 


ааағіме()000000000000000005000000000000600000000 
00000$огідпит00007000000000аадағме()000$огіопит000 
ОД00000059пчтродроОО5 пипоД00500000фогідпипДОДОДОД00 
000005 огідпит ОДОДООО001.00Д0000000000000000000000000 
ООО00000000000000 


ОО0О0000000000000000000000000000000000000000000 
ООО00000000000000000000 


0000.1 ЗОДОДОД0О00000000000000000000000000700000 
О0000000$огідпитроооооооооо000000000000000000000000 
ОЗ.ОДОООО00000000000000000000000000000000000000000 
ОООО00000000&0000000000000000020000 


00007.13 [HII II IILI IILI I III! 


: <?php 
: function addFive(&$num) 
{ 
$пит += 5; 
} 
: $orignum = 18; 
: addFive($orignum) ; 
: echo $orignum; 
2» 


о o — O) QI + cnm = 


О00р00000000Оадапмег.рирродД0О0О0О0000000000УУе 000 
О000000000%еБро000000000000000000000 


15 


7.8 ППППППИП 


ОДООДОО00000000000000000000ОРНАРОООООООО0О0000000000 
ОООО0000000000000000000000000000000000000000000000 
ПОДОМу5ОСПОДОООО00ОО00000МУЗОЗОООООО0О0000000000000 
ПП 


[I function exists()QQ00000000 function _ех1$ї$()ПЦППП 
О0000000000000000000000єгчмер)0000Таїзеб 


00007.1400ОТипсбіоп exists ОПООООО0000000000000000 
000000 


00007.14 ОДО0000000 


1: <?php 

2: function tagWrap($tag, $txt, $func = "") 

3: 

4: if ((lempty($txt)) && (function exists($func))) í 
5: ФЕХЕ = $func($txt); 

6: return "«".$tag.'»".$txt. «/".$tag. "><рг/>"; 
7: ) else ( 

8: return "<strong>".$txt."</strong><br/>"; 

9: ) 

19: ) 


12: function underline($txt) 


13: 

14: return "<span style-V"text-decoration:underline;V"»".$txt."«/span»"; 
15: 

16: echo tagWrap('strong', ‘make те боја ); 

17: echo tagWrap('em', 'underline and italicize те', "underline"); 

18: echo tagWrap('em', ‘make me italic and quote те", 

19: create function('$txt', ‘return "&quot;$txt&quot;"; ')); 

20: 2» 


Орр000000Обадуугарородг00ОчпавФгіпе0 00012000 
сао\ғар()О000030000000000000000000000000000000000000 
П000чпаегіпе()О000000000000000000000000<ѕрап>00000 
у ОП «езрап»ОД000000000 


[000600000 са ом/гар ОО00000000 ‘strong’ 0000" таке 
me bold” ПООДОООДОДО0О0О00000000000000000000000000 4 
ОД00005Фесє0О000000000005тчпсруд00000їипсбоп, exists OTT] 
ОДОД0О00000000000000005Рмпс О000000000000/08002ї5е 0 
ПО 000 5 Егопд 2 00000000 


О000270000007епо'ОДОООО000000" underline " [TT] 
tagWrap()[Jffunction ехіѕ5()0000чпаегіпе() 0000012000000 
ПООООО0000000000000000000000%х#0000000000000000000 
OOL 


00000180000005а9У/гар СООООО000000000000000000000 
О000000000000000000000000ғипсіїоп_ехіѕ5()000000000000 
ОО00000000000 


П00000000000ехіѕѕ.рһро0000000000000000%еюпр0000 
О000000%Уеюро0000000000000000007-8000000 





[5] localhost/Ü7/exists.php 
“т си http:;//lacalhost/Ü //exists.php З, 


make me bold 
underline and italicize me 
"make me italic and quote me" 


П7-8 ехі5і5.рһрППП 


7.9 || 


ОО0О000000000000000000000000000000000000000000 
діобаїП5сайїсЮДОДОООДОПВООПООДОДб0О0О00000000000000000 
00000 


7.10 Q&A 


ОбООООООО00000000000000000000000000000000000 


АООООДОООООО00О00000000000000000000000000000000 
ОООО0000000000000000000 


$newstring = "I purchased".numPurchase($somenum)." items."; 


ОбООООООООО000000000000000000000000000000000 
ӨШ 


АПППИППИПППИППИППИПППИППИПИИИПИПИПИППИППППППИП 
ОООО000000000000000000рБрАп:000000000 


7.11 1100 


ООО0ОО000000000000000000000000000000000000000 


ӨШ 


1П000000000000000000000000000000000 
200000000000 


ЗОООО000000000000 


$number = 50; 
function tenTimesí() í 
$number = $number * 10; 


} 


tenTimes(); 
echo $number; 


АД О00000000000000 


$number = 58; 

function tenTimesí) í 
global $number; 
$number = $number * 10; 


} 


tenTimesí); 
echo $number; 


> ПОДОДО00000000000 
$number = 58; 
function tenTimes( &$n ) 1 


$n = $n * 19; 
} 


tenTimes( $number ); 
echo $number; 


ИЦ 


О О О JC] 


2)0000гесигор000 


30005 0(еп птез( ОООД00000005 пипобегродродооОЗОЦО 
ОД0000000005пиплбет) 


400005000д000910баїрдд000беп Times О000000 
Фпитре [10 


5П00050000000000%п00&000000000000000000%п0 
ѕпитрег1000000000$%п00000000%питрег0000 


ӨШ 


О III II I 


2 JUUUUUUUUUU4 QUO OU TM LO 
ООО00000000000000 


Ns} 0000 


ОО00000000 


• ПОДООО00000000 
° ПОДОРНРОДОДООООООО00О 


ОДОООО0000000РНРОДООООООООООООДОО00000000000000 
ООО0О0000000000000000000000000 


8.1 [JI 


ОО000000000000000000000000000000000000000000000 
ОДО00000005 соїогдд0000Омгеаббьтчеророб0О0О000000000000 
ОДООДО00000000000000000000000000000000/70000 


ОООО0000000000000000000000000100000р00000000000 
ООООООООООООоРНРрООООООООООООООООООООоОоооороооо00о0 


ОбОб00000000000000000кеурдрд0Оматчеророророосоо 
ПОБООО0О0000000000003 00000000000000000000000000000 
ОДООДО0000000000000000000000000/00000000000000000000 
ОООО0000000000000000000000000000000000000000000 


8.2 ПП 


П00000аггау()О00000000010000000000000000000000000 
О00000000000000000аггау()000000000000000000000000000 
ОО0О0000000000000000000000000000000000 


О000000000000аггау()00000000%гаіторомрП00000000000 
OOL 


$rainbow = array("red", "orange", "yellow", "green", "blue", "indigo", 
"violet"); 


ООООО000000000000000000000000000 


$rainbow[] = "red"; 
$rainbow[] = "orange"; 
$rainbow[] = "yellow"; 
$rainbow[] = "green"; 
$rainbow[] = "blue"; 
$rainbow[] = "indigo"; 
$rainbow[] = "violet"; 


ОДОД00000000005 гаіпром7 0000000000000900000006П 
ОООО00000000000000000000000000000 


$rainbow[0] = "red"; 
$rainbow[1] = "orange"; 
$rainbow[2] = "yellow"; 
$rainbow[3] = "green"; 
$rainbow[4] = "blue"; 
$rainbow[5] = "indigo"; 
$rainbow[6] = "violet"; 


ООООО00000000ОРАРООООООООООООО0000000000000000 


$rainbow[0] = "red"; 

$rainbow[1] » "orange"; 
$rainbow[2] » "yellow"; 
$rainbow[5] = "green"; 
$rainbow[6] = "blue"; 

$rainbow[7] = "indigo"; 
$rainbow[8] = "violet"; 


0000000апгау Оророророророоророророоророворороод 
ООООО0600000000000000000000000000000000 


$rainbow = array("red", "orange", "yellow", "green", "blue", "indigo"); 
$rainbow[] = "violet"; 


ОООО0000000000000000000000000000000000000000000 
ООО000000000000 


8.2.1 [DUE 


ООДО0000000000000000020200000000000000000000000 
О000004000000%сһагасёег 00000000 


$character = аггау( 
"name" => "Bob", 
"Occupation" => "superhero", 
"аде" => 30, 

"special power" => "x-ray vision" 


E 


$characterT[][]TLHALIEEIname[]occupation|[]age[]special 
power 00000 ]IBob[]superhero[]30[]x-ray vision| ПП 
ПООДОДООДО0000000000000 


echo $character['occupation 1; 


ОО000000000 


superhero 


ОООО00000000000000000000000000000000 


$character['supername'] = "Mega X-Ray Guy"; 


О000000000О5ирегпатеро0000Меда X-Ray Сиу 


ОО0ОО0000000000000000000000000000000000000000000 
ОО00000000000000000 


8.2.2 (ПП 


ОДООДО0000000000000000000000000000000000000/0000 
ОО000000000000000000/00000000008.10000000%сһагасёегѕ] 
ООООО0Д000000000000000000000000000000000000000000000 
ULL] 


00008.1 010000000 


<?php 


14 

2: $characters = аггау( 

3: array( 

4: "пате" => "Вор", 

B "Occupation" -» "superhero", 

6: "аде" => 30, 

Та "special power" => "x-ray vision" 
8; E 

9: array ( 

10: "пате" => "Sally", 

11: "Occupation" => "superhero", 

12: "аде" => 24, 

131 "special power" => "superhuman strength" 
14: и 

15: аггау ( 

16: "пате" => "Јапе", 

17: "occupation" => "arch villain’, 
18: "age" => 45, 

19: "special power" => "nanotechnology" 
20: ) 

21: ) 

22: ?> 


П020000аггау()0000000%сһагасёегѕ=003080000 
Фсһагасёегѕ=000000000090140000%сһагасёег$р0000000000 
150200000%сһагасёегѕ50000000000000000%сһагасѓёегѕ[0 0 
$characters[1 |[]$characters[2 |] 


ОО0000000000000000000000040000патеђоссирайопд 


age[]special ром ет) 


ООО0000000000000000 


echo $characters[1]; 


ОО00000000 


Аггау 


ООООО000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000 


0000000 


echo $characters[1][' occupation |; 


ОО00000000 


superhero 


ОО000000000000008.100000000000000000000000000000 
0000000 


foreach ($characters as $c) í 
while {list($k, $v} = each ($c)) { 
echo "$k ... $v <br/>"; 
) 


echo "«hr/»"; 


foreach | ППИИИИ $ characters ПП i p pa E E E ECTS CDL] 
ОДОД0О0000000000000000м/пітеродоооборороб0ооррбро000000 


ОО0115:000000000005кО5У0000000ОеаспородоророробоЩО 
еаспОДрр005Є00000000000000000 


есһпо000000000еасһ)000$С00000000000$КО$УрО000000 
О0000000008-10000000тааггау.рћро000000 


ШІСІ Х- 





| localhost/ü8/mdarray.php 


€ С | © http://localhost/08/mdarray.php 3, 





special power ... nanotechnology 


08-1 ПШПШ 


8.3 ПООООО0000 


РАНРООО ООДОООДООПООДО ОДОРЕЄр ://www.php.net/array [| 
ОООО000000000000000000000000 


° count()[]sizeof() - - ООДОООДООО00Д0000000000000000 


$colors = array("blue", "black", "red", "green"); 


count($colors)[]]sizeof($colors) 0040 

еасһ() из )——00000000000000000000000000000О 
ОП5СООО0000000000000000000000000000000000000000 
LIES enr 
foreach()——LDIBDp pp Be m EUBCIHROLUBCIEIDLO CDI EID DICH E TL A 
ОООО 

ге5еї 0--- ПООДООО0000000000000000 


reset ($character} ; 


ОООО000000000000000000000000000000000 


array ри5п0--- ОДОДОДОДО0О0О0000000000000000 


array push($existingArray, "element 1", "element 2", "element 3"); 


array рор()----ОДО0000000000000000000000000 


$1ast element = array pop($existingArray}; 


array_unshift()——()0 0000000000000 00000000000000 
array unshift ($existingArray, "element 1", ‘element 2", "element 3"); 
array_shift()——QOO00000000000000000000000 

$ехіѕііпдАггауроо000000000000%#гѕ еіетег00000 


$first element = array shift($existingArray); 


array merge()—-—-(ULDLDD p mia pO 

$newArray = array тегде(баггау1, Фаггауг); 

array Кеу5()--- ОДОООДО0О00ОО0000000000000000000000 
ПЦ 


$КеузАггау = array keys(S$existingArray); 


° аггау уа!інес()----ППППППИ ПП ПП 
ПП 


$valuesArray = array values(S$existingArray); 


° 5пиНТе0--- ОДООООО000000000000000000000000 


shuffle($existingArray} ; 


ООО0О0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000 
http://www.php.net/array ПРНРООДОДОДОДОДОООДОДОДОДОДОП 
ОООО000000000000000000 


8.4 || 


ОООО0000000000000000000З00000000000000000000000 
ОООО0000ОРНРОООООООДООООООО000000000000000000000000 
ОО0000000000000 


8.5 О&А 


QI IILI II IILI IILI 


АДОООООООООООООвООООООООООООООООООООООвОООООООО 
ООО0О0000000000000000000000000000000000000000 


ОбОООООО000000000000000000 


АДПОООДОДО000/ ООООООО000УУеББООООДООООДОДОДОДОО 
00000 3 20000000000000000000000000000000000000000000 
ОООООД000000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000000 


8.6 ПІП 


ООООО0Д00000000000000000000000000000000000000 


ЧЕН 
11000000000000000000 


2 В000000000000000 


ИЦ 


1Паггау() 


2Паггау merge() 


ӨШ 


ТО 0000000000000000000 


2 ПО000000000000000000000000000000000000000 
Science РіСіОПДАсіопПАамепіигерПододорододроодродооо 


ППППЦПАНеп[Тегтїпаїог 3[]Star \Маг ПООДОДД00000000000000 
ППППППППППППППОПГІ 


090. 0000 


00000000 


° ПОДОООО000000 
• ПООООООО000000000000 


ОООО0000000000000000000000000000000000000000000 
ОДООДО0000000000000000000000000000000000000000РНРОД 
00000 


ООООООРНРОДОООООООО ОО ОООО000000000000000000000 
ПООООРАРООООО 


ПОООРАРООООООВОООООООООООООООРАРООООООООООООО 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО0ОО00000000000000000000000000000 


ОДООДОО000000000000000ОРНРОООООДОДОРНРеОООДОДО 


9.1 ШШШ 


ООО0ОО000000000000000000000000000000000000000000 
ОстабОДООДОООДО0О000000000000000000000геа5соїог TET] 
ОО003004000000005спагассегрДрДОО0000О0000000000000000 
ПП 


ОООО000000000000000000000000000000000000 
Птеёпоар00000000ргорегёурооб00000000000000000000000 
00000000 


ОДОООО0000000000000000ОРНРОПО"Саз5ез and Objects” ППППППППИППИПГ 
http://www.php.net/manual/en/ language.oop5.php 000 


ПООДООДООДО000000000000000000000000000000000000 
ПобиП0ба скоторпедбПасчкоторнедороп ПО соо" такеп 
глоде Пррдашеоторнедрррооооооооооооооооооооооо 
silver[]Mazda[]Protege5|]|]|]Dred[]Porsche[]BoxterrT] 


ОООО0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000 


ООО0000000000000000000000 


class myClass 4 
/jcode will go here 


} 


ООО0О00000000000000000000000000 


$object! = new myClassí); 


000009 .1000000000000000000000000--0000000000 


00009.1 ДО00000 


<?рһр 
class myClass í 
/[code will go here 
} 
$object! = new myClass(); 
echo "\$objecti is an ".gettype($object1).".<br/>"; 


if (is_object($objecti)) (í 
echo "Really! I swear \$object1 is an object!"; 


= = OON OO ON = 


Q: | 
1 


: 9» 


ОДО0000000Пргоогїоїсіаз5. риРрОДОДОДОДОДОДОДОУ/еьОООО 
ООО000000000000 


$objectl is an object. 
Really! I swear $object! is an object! 


ООДО0000000000000000000000000000000020005000000 
00000000080001000015. обуес  ОПОДОООООО00О0000000000070 
07005об)есі1 05 обуес 0 inire ep p p E m IE LI II 


ОООО00000000000000000000000000 


9.1.1 ПОД 


ОООО0000000000Оргорегеу ПООООО00000000000000000000 
ООО0О000000000000000000000000000000000000000000 


сіа55 туСаг { 


public$color = "silver"; 
public$make = "Mazda"; 
public$model = "Protege5"; 


ППОПОВОВОВОООрчонеОргоесеа рима ей II I II III! 


О000000000000000рчюіО00000000000000000ргоѓёесёеад 


00000000000Прпуаєе JE] 
ПОО000000тусСаго00000003000000009.2000000000000 
ИШПШШШШИШШШИПП 
00009.2 00000 
1: <?php 
2: class myCar í 
3: public$color = "silver"; 
4: public$make = "Mazda"; 
5: public$model = "Protege5"; 
6: } 
7: $car = new myCar(); 
8: echo "I drive a: ".$car -> color." ".$car -> make." ".$car -> model; 
9: ?> 


П000000000орјргорегёїеѕ.рћрооО0000000000000\%еюрп00 


ООО0000000000000 


I drive a: silver Mazda Ргоїедеб 


О0000000000000Ма»хаа Ргоќеде51О0000000000тусСат 


000000009.О00000000000 


00009.3 000000 


«?php 

class myCar ( 
public$color = "silver"; 
public$make - "Mazda"; 
public$model = "Protege5"; 

) 

$саг = new myCar(); 

$car -» color = "red"; 

9: $car -> make = "Porsche"; 

10: %саг -» model = "Boxter"; 


: echo "I drive a: ".$car -» color." ".$car -» make." ".$car -» model; 
p 


со чч Фф UO + Wh — 


- — 
№ — 


ППИПИПИПППоВургорегиев2.рһрПППППИПИПИПИПИПУуео rr] 
ООО00000000000000 


I drive a: red Porsche Boxter 


J00000000$color0$makeg$ mode поОПООПОООООПОООПО1ОПОООООПОПООООО 
ООПОб00000000000000000000 | 


00009. ЗОДООО000000000000000000000000000000000000 
0000000 


9.1.2 (ULL 


ООО0ОО000000000000000000000000000000000000000000 
0000009.40000000 


00009.4 — ОДО00000 


: <?php 
: class myClass { 
function sayHello() í 
echo "HELLO!"; 
) 
} 
: $object! = new myClass(); 
: $objectl -> sayHello(); 
. ?> 


(O со ч Oa + ON = 


ОДОО0О0000000000000000000000петПосіавз5. рирооД 00000 
О000000%Уеюро00000000000000000 


HELLO! 


ООООО000000000000000000000000000000000000009-РО000 
ОООО0000000000000000000000000000000000000009.500000 
ПП 


00009.5  ДОД0О0000000 


<?php 
class myClass { 
public$name = "Jimbo"; 
function sayHello() { 
echo "HELLO! My name is ".$this->name; 
} 
} 
$object! = new myClass(); 
$object! -> sayHello{); 
0: 7» 


— (o-00» бо го = 


ООДОДО0000Репосіаз5.риррДОДООООО00О0000О0УУеБООДОДОД 
ОО0000000000 


HELLO! Му name is Jimbo 


О0000050000000000%00000000000000000000000000 
О0000000%150000%.5000-> 0000000000000000000000000 


0000000 


ООО0О0000000000000000000000000000000000000000000 
ОО0000000000009.600000000000 


00009.6  ДОД0О0000000000 


1: «?php 

2: class myClass { 

3! public$name = "Jimbo"; 
function setName($n) { 
$this->name = $n; 
function 5ауне110() í 

echo "HELLO! My name is ".$this->name; 
z$ } 

10: } 

11: $object1 = new myClass(); 

12: $object! -> setName("Julie"); 
13: $object1 -> sayHello(); 

14: ?> 


ОООД0000000Репосіав53.рирООДОООООООДОДОДУУеБОДОО 
ОО000000000000 


HELLO! My name is Julie 


бороброр4а0600000000005еєМатеб 0000000012000000 
О0005 папледддОО че) )000001300О5аунепобод0000000 
$this-2 патер1010чер00000ѕ$еєҸате()0000000000000000 
О0000000000000000000$%патеП00 


9.1.3 ППП 


у000Осоп5сгиссоГПООО0000000000000000000пемуи 
сІіаѕѕ$патеррООо0000000000000000000000000000000000000 


ОООО00000000000000000000000000000000000 


9.2 ШП 


ООООО0000000000000000000000000000000000000000000 
ООО000000000000009.. 700000000 


00009." ОО0000000 





1: <?php 

2: class myClass ( 

cE- public$name = "Matt"; 

4: function myClass($n) { 

5: $this->name = $n; 

6: } 

T: function sayHelloí) 4 

8: echo "HELLO! My name is ".$this->name; 
9: } 


11: class childClass extends myClass 4 
12: //code goes here 


14: $object1 = new childClass("Baby Matt"); 


15: $objecti -> sayHello(); 
16: 7» 


ООДО000000їппегієапсе.рироОДОООООО0000000УУеД0000 
ООО000000000000 


HELLO! My name is Baby Matt 


О4О60000000000000000000000000000000000пусСтаз00 
1101300р00000000свП1аСтав ПЮДООООД0О0ООДО00О000000000000 
О0000000000000000ехеепав рДрОД00002 200000000000000000 
ОО0000000000 


[00000000000000000000000009.80 


00009.8 OOo db o 





со чо O + ON = 


: <?php 


class myClass 
public$name = "Matt"; 


function myClass($n) í 
$this->name = $n; 


} 
function sayHello() í 
echo "HELLO! My name is ".$this-»name; 


} 


} 
: class childClass extends myClass { 


function sayHello() { 
echo "I will not tell you my пате."; 
} 


:) 

: $object1 = new childClass("Baby Matt"); 
: $object! -> sayHello(); 

: ТР 


000009. "О00000000000000000002201400000000000000 


Пваунейтоо а І will not ке you my name" {00 
[| HELLO! Му пате І5...”"ПППППоаунеһоо Паһ !асС!а<<ППЦ 
ОспНасТта55001600000000000000О5аунето 0000 


ОДОДО000000іпРегісапсег.рирбоОДООООДОДОДОДОМУеоОоО0 


ООО0000000000000 


I will not tell you my name 


ООООО0000000000000000000000000000000000000000000 


ОООО00000000000000Н "МЕДООДОДОО0О0000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОООО000000Н МЕООДДООООООО0ООО000000000000000000000000 


ОДООД0О00000000000000000ЕК6-плайодрдроородородородох M LOL 
00000 


ООО0ОО0000000000000000000000000000000000000000000 
ПППНТМІППППЕгла | р  МЕОДООДОООДОДО0О000-000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ULL] 


9.3 ДИ 


ОООО0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
000000 


9.4 Q&A 


О000000000000000О0мамобОрибіїсргімаєегр 
protected|| 


AL[JLIPHPLICIEIEIEIEIE] va r  ОДОО00О00000000000000000000 
маг00000рчюО000000000000000000ргімаѓеПргоѓесіеаП 
ULL] 


ОПОООООООРИРОДООДООООООООООООО00000000000000 


АООООООООООО00ОО00000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОООО00000000000000000000000000000000000 


ПОДООООРНРОДОООООДОРНРООООООДООРЕЄО:/ /лмумум. рћр.пе 
manual/en/language.oop5.php ПОООЦ 


9.5 [ШП 


ОООО000000000000000000000000000000000000000 


ЦЕН 


1000000000етрёусіаѕ$0П00000000000%* 
200000000000000 


ЗОО00000000ргімаёепро0000000000 


ИЦ 


1000<!аѕѕ$000000 


class emptyClass í 
) 


2 ОООО0000000000000000 


ЗПЦПППрпуатеППППШПШШПШШШП 


ӨШ 


10000000ОбазеСсаї  ОООООДО0ОДО000000000000000 
саісшаѓёе()000000000000000 


40000010000900ОгааСаїс )О5иоСаїс )ОПптитсаїс 00 
аімСа1<()000000000саісиаёе()0500000000000000000 


0101 
02.20 
0121 
1130 


1140 


ОЗОД 


ОДО00000000 
0000 

П0Соокіе 000 
0000000 


108 


HOOL 


ILO ДОООДО00000 


00000000 


00000000 
ОО00000000000 
ОО000000000000 
ОО00000000000000 
ОО00000000000000000 
00000000 
ОО000000000000 
ОО0000000000 
ОО0000000000000 
ОО00000000000 
ОО000000000 
ОО00000000 


урммер рДорроооброророон т меррроророрборормевордоо 
ООРНРОДОООООООООО0О0ОО000000000000000000000000000000 
ОО0000000000000000000000000000000006гедогап 
саіепаагуО000000РНРрОВОООООО0ОВО00000000000000000 


ee POOOUUUUUUUUUQUUUUQUUUUUUÜÜUÜUÜUUÜUÜUUUL 
ОООО0000000000000000000000000000000000000000000000 


ОООДОО0000000000000000000000ОРНРОДОООООООО000000000 
ОО0О000000000000000000000000 


10.1 ПОРНРОДОООО 


ОООДОО0000000000000000000000000000РНРОДООДООДО0 
ООО0О0000000000000000000000000000000000000000000000 
О000000000000рппё)Оѕргітғ( 000000000000 


10.1.1 [l|printf() 


ПППППППОПППППИПИПИПИПИПИПргіп er OTI DID Ep rin ef ООООЦ 
ООДОДО0000000000000070пплає control string ПДОДОО0000000 
ООООО00000000000000000000000000000000000000000000 
ргіп'ОООДОДООВОДОДОДОДОЗОДОДОЦО 


«?php 

printf("This is my number: %0", 55); 
ff prints "This is my number: 67" 

Ге 


ОО000000000000000000000000000000000000сопмегѕіоп 
ѕресійсашоп0000000000(%)000000000000ргтёғ) 0000000 
ООДООО00000000000000000000рпіпбОООД00000000000 


ОДОД0000рпібОДОД00000 


<?php 

printf{ "First number: %f<br/>Second number: %f<br/>", 55, 66); 
ff Prints: 

// First number: 55.000000 

// Second number: 66.000000 

2» 


ОДОД0Д000ОргіпеООДОО0000005500000000006600000000 
ОРТОДОООД00000000000000000000000000уре зрестег о 


printf()[| 


ОО00000000000000000000006000000000000#010-10000 
00000000 


010-1 [JHI 


° О00000000000 
ОДООАЗ5ЄНОДОООП 


Pm | 





000010.10П0ргітёғ()000010-1000000000000000000000000 
ОООО000000000000000000000000000000000 


000010.1 ДД0000000 


<?php 

$number = 543; 

printf( "Decimal: %d<br/>", $number); 
printf ( "Binary: %b<br/>", $number}; 
printf ("Double: %f<br/>", $number}; 
printf ("Octal: %o<br/>", $number); 
printf('String: %s<br/>", $number}; 
printf ("Hex (lower): %x<br/>", $number); 
printf("Hex (upper): %X<br/>", $number); 
0: 7» 


= OO nN O) UO + ON = 


ОДОДОД00000рпіпЄбеезі рирДОДОДОДОДОДОДОООПУУеьОДОГО 
ОДО00000УУерооодоД000000000002.0-100000000000000 
ргіпОООДОД00О0000000000000000000000000000 


lacalhost/10/printftest.php 
€ С! | © nttp;//localhost/10/printftest.php a, 


Decimal: 543 
Binary: 1000011111 
Double: 543.000000 
Octal: 1037 

String: 543 

Hex (lower) 21f 
Hex (upper): 21F 


010-1 П00000 


ОН МЕДОДОООООДОДОДОЗОООПРРООООООО00О00000000000 
ОДОООО0000000ргіп0000255000ЗО00000000000000000000 
ПП 


«?php 

егей = 204; 

$green - 204; 

$blue = 204; 

printf("#%X%X%X", $red, $green, $blue}; 
ff prints "ЯСССССС" 


2» 


ООО0б000000000000000000000000000000000000000000 
ООО0Д00000000НТ7МО000000000000000000000000000000000 
DES redri$green(]$ біЙе)00010000000000000000261 1200000 
000000ППраааїпод вресіпегі рОД00000000 


ОЗ000000000 


ООООО0000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000000000000000 
ОДООО000000000000000000000000000000000 


«?php 
printfí('$04d", 36); 
фо prints "0836" 

?> 


ООО0О0000000000000000000000000000000000000000000 
0000 


<?php 

printf("% 4d", 36) 
|| prints " 36" 
> 


есһо "Тһе зрасез will be visible"; 


ППЦПППШШПШШИШШПШШШШШШШППеадег()ЦППШШПСопїепї-ТуреППППШШШ 


header("Content-Type: text/plain"); 


П000000һеааег()О00000000000000000000000000000000 
ОДООО9р00000000000000000000000000000000000 


«?php 

printf ("%'x4d", 36); 
ff prints "хх36" 

72 > 


ОООО0000Н МЕРДОДОООООООООО ОООООЗОДООО00000000 
ООПОДОДОО0000000000000000000 


«?php 

$red = 1; 

$green = 1; 

$blue = 1; 

printf("4902X$02X$02X", $red, $green, $blue}; 
ff prints "#010101" 

2» 


ООООО000000000000000000000000000 


10.1.2 UN 


О00000000000000000000000пеа width ѕрестег 000000 
ОООДО00000000000000000000000000000000000!000000000 


ОО0000000200000000000000000000000000000000000ргепо 
ПП 


«трир 

echo "<pre>"; 

printt("*28s\n", "Books"); 
printf('$280sin', "СО57); 
printt("%*28s\n", "DVDs"; 
printf('*20sin', "Games"); 
printfí('*20sin'", "Magazines"; 
echo "</pre>"; 

“> 


020-2000000000000 





[5] localhost/10/sample.php 


б C ©) hitp://localhost/10/sample.php З, 


Magazines 


[10-2 ПППППИПИПИП 


ОООО0000000000000000000000000000000000000000000 
000000 


printf("%-2@s\n", "Left aligned"); 


ООО0О0000000000000000000000000000000000000000000 
ООО0000000000000000 


0000 


ООО0О0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОО000000#00000000000000 


<?php 

printt("%.2f", 5.333333}; 
Іф prints "5.33" 

2 


0С0000000рип')0000000000000000000000000000000РНР00000000000000 
00000000000000000 | 


0000000 


01 0-2000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000 


[10-2 ДОДОДОО0О 





00000 ОООО000000000000000000000000 na 
0000000 О0000000000 


00000 ОО0000000000000000 С 
00000 О0000000000 2 


000010.200ргіті()00000000000000 





000010.2 дОргіпЕРООДОДОДО000000 


«?php 

$products = array("Green armchair" => "222.4", 
"Candlestick"=> "4", 
"Coffee table"=> "80.6"); 

echo "<pre>"; 

printt("%-2@s%2@s\n", "Name", "Ргісе"); 

printf ("%' -40s\n", ""); 

foreach ($products as $key=>$val) í 

printf( "%-20s%2@.2f\n", $key, $val ); 


O чол Бо N = 


— — (0 
— © ++ 


: еспо "«/рге»"; 
: 2< 


— 
№ 


ОО000002000400000000000000000000050000ргео00000 
ОДОО0000000000000006П0ОргіпєГОООДООДС0О00000000000000 


'%s-205%205\n" 
ПООООООООООООО000* %-205” 0000002 О000000000000000 


ООДОО0000000000000000000007 %205* В0000000000000000 
ргіпЕРООООО0000000000 


ОУ0ОргіпбРОООД0000007 = "ОО00000040000000000000000 
ОООО0000000000000000000 


ПӘППргіп ТОППИПИППППИП Fe rea слооооооововооообоц 
0000007 7о-205" ДОДОДОООО00000002000000000000000000 
0"792о20.2Р"О00000000000000000000200000000000000000000 
ОО00000000000000 


ППИПИПИПИПЦПИргіп Геве2  риРООДОДОДОДООДОООДОДУУевсоО 
ОД000000000УМе ор орообоб0000000000010-3000000 





lacalhost/10/printftest2.ph 
€ C ©) hnttp/localhost/10/printftest2.php 3, 
Hame Price 
Green armchair 222.40 
Candlestick 4.00 
Coffee table 80. 60 


010-3 П0ргітё( 00000000 


10.1.3 ПІІ 


ОО0000000000000000000000000000000рет{ 00000000 
ПППП 


«?php 

$dates = array( 
array('mon'-» 12, ‘mday'=>25, 'year'-»22011), 
array('mon'-» 1, 'тдау'-»23, угаг'=>2012), 
array('mon'-» 18, 'mday'-229, уеаг'=>2011) 
); 

$format = include("local format.php"); 

foreach($dates as $date) { 

printf('$format', $date['mon'], $date[ mday 1, $date[ year']}; 


2» 


ООД000000000000000000010саї fermat. ph pri bb ILI I I 
00000000 


«?php 
return '502d/*:028/*sd«br/»"; 
2» 


ОО00000000000пп/аа/уууурб 


12/25/2911 
01/23/2012 
10/29/2011 


ОООО00000000000000000000000000000000000000 
Паа/тт/ууууро0000000000000000000000000000000000000 
О0000000000000000000гесито ООН 


return "%2\$02d/%1\$02d/%3\$d<br/>"; 


ОО000000000000000000000000000000000000000(%)0000 
ОО0О00000000000000000 


5219024 


00000000 


51192024 


ЕЕНЕЕЕЕШЕ 


153154 


ООО0О00000000000000000 


25/12/2911 
23/01/2012 
29/10/2011 


10.1.4 ПИОООООООО 


ргіпіОООДОД00О000000000000000000000000000Д5ргіпб0) 
ОДОДОО0000000рпіовРООДО0Д0000000000000000000000000000 
ООергіпЄООД0000000000000000000005са5п00 


«?php 

$cash = sprintfí("'*.2f", 21.334454); 
echo "You have i$$cash to spend."; 

ff Prints "You have $21.33 to spend." 
2» 


ППППППӘргіп ТОПИППППППИПИППППИПИПИПГПӘргіп ТОППИПИП 
ОООДООО00007риє5 О00000000000000 


10.2 ППРАНРОГОЛО 


ОДООО0О0000000000000000000000000000000000000УУ/еб 
ОДООДО000000000000000000000000000000РНРОДОДЗОДОО000 
ОО00000000000 


10.2.1 ПИООООДООООО 


О000000000000000000"00"О0таехр000800000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000 


«?php 

$test = "phpcoder'; 

echo $test[0]; // prints "р" 
echo $test[4]; // prints "о" 
2» 


ОООО0000000000000000000200000000000000000000000 
ООО000000000000000000 


10.2.2 П05&ғем() 0000000000 


О000000005еп()О0000000000000000000000000000000 
ОО0000000000000000000000000005еп()О00000000000000 
ОДОДО000000000000000000000!0000000 


«?php 

$membership = "pAB7'; 

if (strlen($membership) == 4) í 
echo "«p»Thank voul«s/p»"; 

| else 4 
echo "«p»Your membership number must be four characters Јопд.</р>"; 


} 


?> 


ПШШ$тетрег<$1рЦППШППШППШИШИЦШПИППШПП&АППИШШИИШШИИИШ 
ОО000000000000 


10.2.3 [|jstrstr()[| E ED IL 


0000005656) 00000000000000000000000000000000000 
ОООО0О0000000000000000000000000000000та15еродрор0000 


ОДООДОО0000000000000000000000000000000000000А 00000 
ОДОДООАВОДООО0О000000 


<?рһр 
$membership = "pAB7"; 
if (strstr($membership, "АВ")) í 
echo "<p>Your membership expires soon!</p>"; 
) else 1 
echo "«p»Thank you!l</p>" ; 


2» 


ППППФтетбегвһірГ ІП ПП ПАВПв те ОПППППППАВ7ППП 
О0000000000000гиеро000000000000"Үоиг membership 
expires воол!”"ПППППППИППППППИГ раб /"ОО0000000000 
strstr) ПОООДОДО0О000АВОДООІЄООО0ООО000000000000000 
(“Thank уои! ”)О0000000000000АВраб000005ч0ѕг() 0005г 
ООО0000000000000000000000000 


10.2.4 Петров ОПОООД0О00000 


ѕгроѕ()О0000000000000000000000000000000005гроѕ() 
ООО0О0000000000000000000000000000000000000000000000 
ОООДООО000000000000000000000053гро5 000000гаї5ерор0000 
О000000000000000005роѕ()000000000000т2000 


«?php 

$membership = "П200ху2"; 

if (strpos($membership, "mz") === 0) ( 
echo "Hello mz!"; 


j 


2» 


ОДОООО0000000000000053гро5 0000000000000пп220000000 
О000000000000005гроѕ()0000000ғаіѕе000#00000ғаіѕеп00 


ПООООО0000000000000002: = = 0000000000000000000000000 
ООО0О00000000000000кгиеб 


ПОПОООбауаск$ )0Опееаїев ПОДОДООО0ОПО0О00000000 
РАРОООООООООО000000000000000000000 


10.2.5 Пзшб5вєгОДОДОДОДОДД 


substr() ОООД0Д00000000000000000000000000000000000 
ОО0О0000000000000000000000000000000000000000000000 
ОДОДОО000000000000000000000000000000000005м 6530000 
ОО000000000000000 


<?рһр 

$test = "рһрсодег"; 

echo substr($test,3)."<br/>"; ff prints "coder" 
echo substr($test,3,2)."<br/>"; // prints "со" 
2» 


О000О5и5528ГОООДО0О0О00000000000000000000000000000 
ОДОД0О00000000000047000Е2плайодорооророодод 


<?рһр 
$test = "ріеггедмападор.їг"; 
if ($test = substr($test, -3) == ".fr') í 
echo "<p>Bonjour! Nous avons des prix spéciaux de vous.</p>"; 
Y else í 
echo "<p>Welcome to our store.</p>"; 
} 


2> 


10.2.6 [I|[|strtok() |) lll] 


LEID EIseree KOLTTEIDDIDEIDI BIETET OD EO HEC CD EDO DCID CIEL TL 
ООООО000000000000000000000000000000000000000000000 


О00000005ок()000000000000000000000000005&*ок()0000 
ОО0000000000000000000000000000000000000000000ға/ѕеП 
ЅгёоК()О0000000000000000000010.3005%ок()000000К 00 
ПООООООООвОвООвООвОвОвООвООвов/Оц 


000010.3 П050ок()0000000 


: <?php 
: $test = 'http://www.google.com/search?"; 
: $test .= '"hl-en&ie-UTF-8&q-php*development-books&btnG-Google*Search"; 
: $delims = "78"; 
: $word = strtok($test, $delims); 
: while (is_string($word)) { 
if ($word) { 
echo $word. "<br/>"; 


} 
Q: $word = strtok($delims) ; 


= — — OO nN OO UHR c0 — 
— чи па и. 


2: ?> 


OOOOOOOOOOOL teststrtetok. php ОО000000000000000\%ео 
О000000000000%еюоо000000000000000010-4000000 


localhost/10/teststrotok.ph 
€ С ©) hitp://localhost/10/teststrotok.php 


http:/^www.google.com/search 








а-ріш-а =“ 2|ортеп 
btnG-Google- Search 


П10-4 teststrtotok.phpL[]LIELILILILILILILILILILI 


ѕігёок()О0000000000000000000000004000000000000000 
О000000000%аеітѕ0050005&%ок()00000000к: 0%аетѕр0 
ОО00000000000000000005мумсгад)00600м'пітеродороорбр00000 
ФмуогаПОП000000000000000000000000000000000000000 


ОООО0000000000000000000000000000000000000000000 
П0000000000005ок()0000000000000000000000 


while ($word) | 
Sword = strtok($delims}; 


LI LIS ммогарООДОДО0О0О00000000000000000 


00000005 мога 0000000000000000005 we rd П 0000000 
О00080000000000000000010000005%ок()0000000000%мога 
ОО0000000000000000005&ок()000000000000000000000000 
ОО0000000000 


10.3 ПРНРОДОДОО 


РАРОООООООООО0О0О00000000000000000000000000000000 
ПП 


10.3.1 [jjjtrim()[]ltrim()[]strip tags О)ПОПОООП 


ООО0О0000000000000000000000000000000000000000000 
(trim ООДОДОС0О000000000000000000000000 Te ООООДО000000 
ООО0О000000000000000000000 


«?php 

$text = “"\titlots of room to breathe 

echo "<pre>$text</pre>"; 

ff prints " lots of room to breathe 
$text = trim($text); 

echo "<pre>$text</pre>"; 

ff prints "lots of room to breathe"; 

2 


ОООО0000000000000000000000000000000000000000000 
ПОООРНРДе ти ОООООД0000б7іпоОООД0О0000000000000000000 
00000000 


<?php 

$text = "\t\tlots of room to breathe E 
echo "<pre>$text</pre>"; 

ff prints " lots of room to breathe 
$text = rtrim(Stext}; 

echo "«pre»$text«/pre-"; 

ff prints ^" lots of room to breathe"; 
2» 


РНРОПО іп ООДОДОДОО0б0О0000000000000000000000000 
О000000000000000000007таооо00000000000 


<?php 

$text = "\t\tlots of room to breathe E 
echo "<pre>$text</pre>"; 

ff prints " lots of room to breathe 
$text = ltrim(S$text); 

echo "<pre>$text</pre>"; 

ІІ prints "lots of room to breathe А 
2> 


ОООДО0000000000Н TM LOOP H PUOL 
strip (ад 0 П000000005йтір. сад50 ПОО000000000000000000 
strip (ад ООДОДОН ПМЕДДОДОООДОДООБОДОДОДОДО00000000 


«?php 

$string = "<р>\"Т <em>simply</em> will not have 14,1" <br/>said Mr Пеап.</р> 
«p»«strong»The end.</strong></p>"; 

echo strip tags($string, "<br/><p>") ; 

2» 


LOIDEIDEIEDDIDCOIDEIDIEIEIH TM ECTEIHIETEIIDUILIUstri p. tags ODIDUIDIL] 
$string ООДОДООО0000000000000«р2 D бгеООО0000000000000 
DEUEIDUIEIS p DBDIDUILI </p> 00000 


ОЗ000000000 


"I simply will not have it," 
said Mr Dean. 


The end. 


ОО000000000000000000000000 


10.3.2 || биббіг геріасе() 00000000000 


substr геріасе()00050ч05їг()000000000000000000000000 
ОООО000000000ЗО000000000000000000000000000000000000 
0000005ч0ѕ#г геріасе()Ј0000000000000000000000000000000 
ООО0000000000000000000000 


ООООО000000000000000000000000000000000 


«?php 

$membership = "mz11xyz"; 

$membership = substr replace($membership, "12", 2, 2); 
echo "New membership number: $membership'": 

ff prints "New membership number: тгі?хуг" 

2» 


ООДО000000000007/ т211ху2"П000000000"т212ху2 T] 
10.3.3 [$ гер!асе() UI U) 


str геріасе()О00000000000000000000000000000030000 
ООО0О00000000000000000000000000000 


О0000005г геріасе()0000000000201010000020120 


<?рһр 
$string = "«hi»The 2010 Guide to All Things Good in the World</h1>"; 
$string .- "<p>Site contents copyright 2019.</p>"; 


echo str replace("29010","2012", $string}; 
2» 


str_replace  ОДОДОДОО0О0О00000000000000000000000000 
ООО0О00000000000000000000000000 


«?php 
$source = array ( 
"The package which is at version 4.2 was released in 2005.", 
"The year 2885 was an excellent time for PointyThing 4.2!"}; 
$search = аггау{ "4,2", "2005"); 
$replace = аггау{ "6.3", '2012"); 
$source = str replace($search, $replace, $source); 
foreach($source as $str) í 
echo "$str<br>"; 


} 


2» 


00000000 


The package which is at version 6.3 was released іп 2012. 
The year 2012 was an excellent time for PointyThing 6.3! 


О00000000005ї7_геріасе()О0000000000000000000000000 
ОО00000000000000000000000000000000005г_геріасе()0000 
ОО0О00000000000000000000000000000000000 


10.3.4 ПШ 


РАРООООООООО0000000000000,.0000000000000000000000 
ОДОО000000005геомррего ДоДДОПОООД00000000000000000000 
0000000 


«?php 

$membership = "mzllxyz"; 

$&membership = strtoupper($membership); 
echo "$membership"; // prints "MZ11XYZ" 
2 


О00000000000000005їгоіомег()00000000000000000000 
ОО0000000000000000000 


«?php 

$membership = "MZ11XYZ"; 

$&membership = strtolower($membership); 
echo "$membership"; // prints "mzllxyz" 
2» 


РНРОООО000000000000000000чсмогаѕ() 0000000000000 
ООООО00000000000000000000000000000000000000000000 


<?рһр 

$full пате = 'violet elizabeth bott"; 

$full пате = ucwords($full name); 

echo $full name; // prints "Violet Elizabeth Bott" 
25 


ООООбО000000000000000000000000000000000000000000 
ОДОД5 ПІАЄДОДОДОДОДОМІОЇГЕЄ eLIZaBeTH bOTt[]ucwords()LLILILI 
ОООООДО0О000000000000М101ЕЄ ЕІ аветнвотеророоїб 
ПО0000000чсмогаѕ( 00005 гоіомег()О000000000000000000 
ОДО0000000 


«?php 

$full name = "VIolEt eLIZaBeTH bOTt"; 

$full name = ucwords(strtolower($full name)); 

echo $full name; // prints "Violet Elizabeth Bott" 
2» 


ПОриспг5 tO p a OE CECI CID CCCII CD CIC TL 
ОО000000000000000 


«?php 

$myString = "this is my string."; 

$myString = ucfirstí($myString); 

echo $myString; // prints "This is my string." 
2» 


ОООО000000000000000000000000000000000000 
Lj МуРаѕѕ ППООО000" mypass "ООООООО0О000О00000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000 


10.3.5 [l|l|wordwrap()[InI2br()LLLLI 


Поромеврроовововоооовововоововововоооововоцо 
пі26гО ООДО000000000000Н 7мО00000000 


<?php 

$string = "one line\n"; 

$string .- "another line\n"; 
$string .= "a third for luckin"; 
echo nl2br($string) ; 

2» 


ОО000000000 


опе line<br /> 
another line<br /> 
a third for luck<br /> 


пі26гО ООДО0000000000000000000000000000000000000 
О0000000000000%могамгар()000000000000000могамгар()00 
ОО000000000000000000%могамгар()000075000000000000\%0 
ОО00000000000000 


«?php 

$string = "Given a long line, wordwrap() is useful as a means of "; 
$string .- "breaking it into a column and thereby making it easier to read"; 
echo wordwrap($string); 
2» 


ООО000000000000 


Given a long line, wordwrap() is useful as a means of breaking it into а 
column and thereby making it easier to read 


ELOIBEIDEIEE Nn IBODUIDIBIEIEICID R 71М000000000Омумогамгар ДО 
ООООО00000000000000000000000000000000000000000000 


echo wordwrap($string, 24, "<br/>\n"}; 


[III S string EDU CETTE] 


Given a long linge, <br/> 
wordwrap() is useful as<br/> 
a means of breaking it<br/> 
into a column and<br/> 
thereby making it easier<br/> 
to read 


ООО0000000000000Оммогамугар ПООООООООДОДОДОДОДОДОДО 
ОООО000000000000000000000000000000000000000000 
ммогамгар()00000000000000000000000000000000000000000 


«?php 

$string = "As usual you will find me at http: //www.witteringonaboutit.com/"; 
$string .- "chat/eating green cheese/forum.php. Hope to see you there!"; 

echo wordwrap($string, 24, "<br/>\n", 1); 

9» 


Ав usual you will find<br/> 
me at<br/> 
http://www.,witteringonabsbr/-» 
outit.com/chat/eating gr<br/> 
een cheese/forum.php.<br/> 
Hope to see you there! 


ОО000000000000 


As usual you will find<br/> 

me at«br/» 
http://www.witteringonaboutit.com/chat/eating green cheese/forum.php. <рг/> 
Hope to see you there! 


10.3.6 Пехріоае() 050000000 


ехріоде()0005гок()О00000000000ехріоае()0000000000 
ОО000000000000000000000000000000ехріоае()00000000000 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000 
ѕігёок()О0000000000000000000000000000000000000000000 
HEI 


<?php 

$start_date = "2012-02-19"; 

$date array = explode("-", $start date); 

fi $date array[0] == "2012" 

{{ $date array[1] == "@2" 

fi $date array[2] == "19" 

echo $date array[@]."-".$date array[1]."-".$date array[2]; 
ffprints 2012-02-19 

2» 


ООООО00000000000000ОРНРеОООООООООДО000000000 


10.4 ППРАРОДОООООДО 


ОДООДОО0ОРНРОДОООООООО ОООООООО00000000000000000000 
00000000 


10.4.1 [j] time()[][|[][ | 


РНРГ тео ОООДОДОДООО0ОО0О00000000000000000000000 
ОООО000000000000000000000000000000000 


echo timeí); 
ff sample output: 1326853185 
ff this represents January 17, 2812 at 09:19PM 


timeQUUUUUUUUGMT 19/7900101000000000000000000 
ОМІХОДОДУМІХ EpochDpD paa LI [time stampi 
РАРООООООООООО0ОО0О0О000000000000000000000007 000000 
ОООО000000000000000/ О00000000000000000000000000000 
ООО0О00000000000000000000 


ООО0О0000000000000000000000000000000000000000000 
О00000000000000000001999П120310000000000000000000 
10000000100000000200000000000000010000000000000000 
ОО0000000000000060х60х 240086400000000000000000000 
ООО00000000000000000000 


10.4.2 ([||getdate()Q00000 


ОДОД0О00000000000000000000000000009есаасерро000 
ОО0000000000000000000000000000000000009еѓёааѓе()00 
Єтте()0000000000010-ЗрО000009еааќе() 00000000000 


[10-3 деїаае() 0000000 


| р 
И 
- ер — 
ЖЕН и и 


000010.400200П9екаатер ДОбОДОрО000000030000 
гогеа са ПД00000000000000020-5000000009есаасерррошр0000 
00000 





[5] lacalhast/10/getdate.php 


€ С! | © http://localhost/10/getdate.php A 


seconds — 11 





О = 1326853271 


Today's date: 1/17/2012 


010-5 [j[]getdate() 


000010.4 [getdate о 00000 


1: «?php 

2: $date array = getdate(); // по argument passed so today's date will be used 
3: foreach ($date array as $key -» $val) ( 

4: echo "$key = $val<br>"; 

a | 

6: 7» 

7: <һг/> 

8: «?php 

9: echo "<р>Тодау 5 date: ".$date array['mon']."/".$date array['mday']."/". 
10: $date аггау[ 'уеаг']."</р>"; 

11: ?> 


ООО0О0000000000000000000 


Warning: getdate(): It is not safe to rely on the system's timezone settings. 
You are *required* to use the date.timezone setting or the 
date default timezone setí() function. 


П000юһр.ітіП0000000000000000000000 


; Defines the default timezone used бу the date functions 
; http: //php.net/date.timezone 
;date,.timezone = 


[Idate.timezone[|[|[|[ |[ | IL I I[ IL IL) 
http://php.net/date.timezone ПОООООООООВООВОООО 


; Defines the default timezone used by the date functions 
; http: //php.net/date.timezone 
date.timezone - America/New York 


ООДОрИр.іпібДдОДОДОПОАраспеб 


10.4.3 ППааве() ІШІ 


ОО000000000000000000000009еёааёе()000000000000000 
о00000000ааёе()0000000000000000000000000000009аѓе()0 
ОО0000000000000000000000000000000009ағе()0000000000 
0001 0-а00000000000000000000000000 
http://www.php.net/date П00000000000009аёе()0000000000 
ООО000000000000 


[10-4 [ШШааҝ̆е() 00000000 


m ВИ 
[шшш — w 
€ س‎ 
INN NN 
И 
па | 
пи | 
= 
И ВИ 


> Rm 
pem и 
eee | 
mm И 


ППВЕС 8220000000 Tue, 28 Feb 2006 


[]http://www.faqs.org/rfcs/rfc822.html [| 06:45:26 -0800 





и --. 


000020 5000000000000000 





000010.5 ППаагео 000000 





1: <?php 

2: $time = time(); //stores the exact timestamp to use in this script 
3: echo date( m/d/y G:i:s е”, $time); 

4: echo "«рг/»"; 

5: еспо "Тодау 15 "; 

6: echo date("jS чої F У, \a\\t giia \i\\n e", $time); 

7: 7» 


000020 .5000О4асеобороорозоборороподдодорДороровод 
ОД0Д00000000000000000000000Пдасесезі. РЕРДООДОО0000 
\Ме ПООДООДОООДОДО0О0О0О0000000000000000000 


01/17/12 21:29:31 America/New York 
Today is 17th of January 2012, at 9:29pm in America/New York 


ООО0О0000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ООООО000000М40000000000000000000000000000000010.5ПП 
ПОООООМЕЦ 


ППШПШШЦШШПШИШШИПИШШИПШИШИИШИШШШШКПеПППЕПеЦПП3ЗПШШПП 
ОО000000000000000 


<?php 
echo date('l \t\h\e 16”); 
Á/prints Tuesday the 3rd 
?> 


оП00000ааѓёе()0000000000000000006мТО0ОО000000000 
отааќе()000000000000ааќе()00000 


10.4.4 ППткЕенпе() ПООО 


ОПОООО000000000000000000000000ткіте()000000000 
П00000ааѓе() 0оедаѓе()0000тКкєте()0000000006000000 


° ДО 


000010.600тКките()00000000000000009ағе()000000000 
ПП 


000010.6 ЏОгаките( о ДО00000 


: «?php 

: // таке а timestamp for Jan 17 2012 at 9:34 рт 

: $15 = mktime(21, 34, 0, 1, 17, 2012); 

: echo date("m/d/y G:i:s е", 315); 

: echo "<рг/>"; 

: echo "The date is "; 

: echo date("jS \of F Y, \a\\t g:ia \і\\п е", $15 ); 


E 2> 


о 400i + о о — 


о000зО00ткте()000000000000%500000000400070000 
Пааѓе()О0000000%П000000000000000000тките()0000000 
ОО000000000000000000пхкбі m e O ОО000000000000000000025П 
ООДОО0О0000000000000000000002::00 апп 


П000000000ткЕтеѓеѕ.рћро000000%еюрп00000000000 
000000 


01/17/12 21:34:00 America/New York 
The date is 17th of January 2012, at 9:34pm in America/New York 


10.4.5 Псћескааје (()[|||| 


ООО0О0000000000000000000000000000000000000000000 
П0000сһескааѓе()00300000000000000000000101200000000 
ООДОО000000000000000000000000000032 767000 
сһескааѓе()О0гиер0000000сһескаағе()О000000000000000 
ОООО0000000000000000х0пцер 


checkdate(4, 4, 1966) 


ООО0000000000пкоїппеобО0б00000000000-120000000000 
О0000ппкбіпе00019020Д0000000000000000029 700000000000 


ОООО00000000000000009МІХО000019 7011111ШШШШШШШШШШШП 
ОО0000000000 


10.5 ПОООООООООООЦ 


РАРООООООООДОО0000О000О0000000000000РАРОООДОДО0000 
0000 


е Strings[]http://www.php.net/manual/en/ref.strings.php 
• Date/Time] 
http://www.php.net/manual/en/ref.datetime.php 


ОДОДО00ОРНАРООООООООО ОО ОООО0О00000000000000000000 
ООО00000000000000000000 


10.6 |! 


О000000000000000РНРОО0000000000000000000рпёғ) 
5ргіпОДОДООДОООб0О00000000000000000000000000000000000 
О00000000000000051еп()00000000000000 strees ООООО0000 
ОДО0000000 ѕчюѕёг()О000000000000005ок()000000000 


ППППППППППИППППППППППП ЕГІ Т Оба ( rtrim О000000000 
[LLL IL I LL Istrtoupper()[Istrtolower()[jucwords()[|[ II IL II III] 
ППППППППП5їг_гер!асе()ППППППППППППППП 


ОДООД0000000ОРНРОООООДООООО0ОД0000Є6 m e O 0000000000 
ПО0000000000000009еёааќе()00000000000000009аёе()605000 
П000000000000000000000тКкёіте()00000000000000 
сһпескааѓе()О000000000000001600000000000000000000000 
ПОО0000000000000О0000000000Му5ОЦТОО0РНРО 


10.7 [ПЦ 
ОООООД0000000000000000000000000000000000000 


10.8 Q&A 


ОбООО000000000000 


АООООДООООООО0ОО00000000000000000000000000000000 
00000 


ОбООООООО0бО0000000000000000000000 


АПОО001 60000000МУу5ОС0ОО0О000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОДООДО00000000000000000000000000000000000000000РНРО 
00000000 


ӨШ 


ІДД0000ргіпЄООДООД0000О000000000000000000000000000 
ЗЗОО000000 


2 П0000000001000000000000000040000000 
ЗОДОООД0000000000000000000000000 

АД ОО000000000000000000000 
ЗОООО0000000000000 
бООООО00000000000000000000000 
ТОДОРАРОДООООООООООД00О000009 МІХОДОД 
ЗОДОРНРООООООООООО0ОО0000000000000000 
ЗОДОДОРАРОДООООДООО0 


1 ОПООДОРНРОДОООДОО0ЧО0000О 


ИЦ 


Е III! 


printf("*f'", 33); 


2 П00000000000000рппёғ)ОО00000000000000000000000 
ОО00000000 


ргіпеб( 5045", 33); 


ЗОООО0Д0000000 )00000000000000000000000000000000 


printf("*04,2f", 33); 


4О5иб5ЕГООООДО0О00000000000 

о па ООДОООД000000000000 
бПехріоае()0000000000000000 
7000те()000 
враеѓааёе()000000000000000000000000000 
9р00Одаєе0Д 


10[] ]jcheckdate 0000000000000 


ӨШ 


ІППППППППППИППЕ-таЙЦ ПП ПП 
ОДОО0О0000000000000000000ЕК6- пайдрродобоеєбро00000000 
00000 


2 П000000000000000000000000000000000200000000000 
О000000200000000000000 


ЗОПОДОД0000000000000000000000000000000000000000 
ООО00000000000000 


ILL [HII] 


00000000 


ОО0000000000 

ОО00000000000000 
ООООДО00000000000нП7МЕ0ОДОДООО0ОРНРООП 
ОО0000000000 

ООО00000000000000 
ПППППППИПНТМЕЦТГІРНРГГІП 
ООООД000000н7МЕСДОДОДОООООД0О0П 


ООООДООО000ОРНАРООООООДОООООООО00000000000000000000 
ОДОД0О0000000000000000000000000000000000УУеБбО0000000 
ОООО00000Н МЕДОДДОООООООООООО00000000000000000000000 
ООО0000000000000000000000000 


11.1 (ПП 


ОООО000000Н МЕОРАРОДОДО000001.1.100000000Н7МЕ000 


000011.1 ПІПНТМЫИЦЦ 





<!DOCTYPE html» 


«form method="post" action-"send simpleform.php"» 


1: 

2: <html> 

3: «head» 

4: <title>A simple HTML form</title> 
5: </head> 

6: «body» 

rn 

8: 


<p><label for="user">Name:</label><br/> 

9: <input type="text" id="user" name="user'></p> 

10: <p><label for="message">Message:</label><br/> 

11: <textarea id="message" name="message" rows="5" cols="4@'"></textarea></p> 
12: «button type="submit" name-"submit" value="send">Send Message</button> 
13: </form> 

14: </body> 

15: </html> 


ООДОД0000000 simpletorm.htm! ОПООДОДОО0000000 Webi 
ООООО000000000000000000000009000000007 user 0000000 
1100000000" message"  ПООО0000001 200000000000РОВМОПО 
ACTIONI[IIIII IILI ѕепа ѕітріеѓогт.рпроб00000000000000000 
ООПРО5 Т00000000000000000000+_РОЗТОЦ 


000022.20000000000000 


00004 1.2 ООДО00000 


1: <!DOCTYPE html» 

2: <html> 

3: «head» 

4: <title>A simple response</title> 

5: </head> 

6: «body» 

7: <p>Welcome, <strong><?php echo $ POST['user']; ?></strong>!</p> 
8: <p>Your message is: 

9: <strong><?php echo $ POST['message']; ?></strong></p> 
10: </body> 

11: </html> 


0000000000005епа ѕітріеѓогт.рһроб000000000000 
УчерБ ПОООД0Д0О0000000000000000005ітпріетопит піт) 0000000 


00002 1-2000000 


шамаға baa 
ЕЛ inl 
Ipsam а А 

] 


== | [2] | х 


А simple response 
€ C ©) nttp;//localhost/11/send simpleform.php x 
Welcome, John Smith! 


Your message 15: I like cheese! 


[11-1 simpleform.html[]T DIL 


О0000000022.2000000000000000021.20000000000212.20 
ООООО00000000005. POST. Гивег 10$ POST ['те55$аде'1ЦШШШПП 
000005 РОЗ ТООДОДОДОДО0000000000Оч5егс)000Опеззадед П 
ООООРНРОДОООООДОДОД 


ОООО00000000000000000000000000000000000 


ОДООО0О0000000000000С E ТООПРО5ТОДО0006 ЕТООПООПОООООПООООПООООВООО 
О0006ЕТООО00000000000%_6ЕТО00% POSTT] | 


11.2 (0000000000000 


ОООО0000000Н 7МЕРОООООООООДОО0000000000000000000 
ООООО00000000005ЕС-ЕС ТОООООДООООДО00000000000000000 
OOUSELEC ТООООООООООООО0О0000000000000005ЕСЕСТОДОООО 
ПП 


«input type="checkbox" id-"products" name="products'> 


[0000000000000000000($_РОЗТ Гргоаисіѕ' 10000000000 
ОООО00000000000000000000000000000000000000000111.300 
OOL 


000011.3  ООООБЕСЕСТОООНТМЦЈЦО 


<!DOCTYPE html» 

«html» 

<head> 

<title>An HTML form with checkboxes</title> 
</head> 

<body> 

«form action="send_formwithcb.php" method="POST "> 
<p><label>Name:</ label><br/> 

9: <input type="text" name="user" /></p> 

10: <fieldset> 

11: <legend>Select Some Products:</legend><br/> 
12: <input type="checkbox" id="tricorder" 


oO - O, O + Wah = 


13: name-"products[]" value="Tricorder"> 

14: «label for="tricorder">Tricorder</label><br/> 
191 

16: «input type-"checkbox" id-"ORAC AI" 

1%: name-"products[]" value="ORAC AI"> 

18: «label for-"ORAC АТ">ОВАС AI</label><br/> 

19: 

20: <input type="checkbox" id="HAL 2000" 

21: name-"products[]" value="HAL 2000" > 

22: «label for-"HAL 2000">НА( 2000</label> 


23: </fieldset> 

24: «button type="submit" name-"submit" value-"submit"»Submit Form</button> 
25: </Тогт> 

26: «/body» 

27: </html> 


LICIDEIDIEIEI ELTE CL ferm wi its elect. hem ОДОДООООД000000УМевб б 
ОО000000000000000000000000000000*ргоаисёѕ П'ОДОДОДОП 
000000000$_РОЗТ [products ІДОДОО00000012000220000000 
О0000000001.1.4000000000000000000 


000011.4 0000012.300000000 


<!DOCTYPE html» 
<html> 
<head> 


<title>Reading checkboxes</title> 
</head> 


<body> 

<p>Welcome, <strong><?php echo $ POST['user']; ?></strong>!</p> 
<p>Your product choices are: 

9: <?php 

10: if (lempty($ POST['products'])) { 

11: echo "<ul>"; 

12: foreach ($ POST['products'] as $value) í 

13: echo "<li>$value</li>"; 


CON OM т O N — 


15: echo "</ul>"; 
16: } else { 

17: echo "None"; 
18: } 

19: ?> 

29: </body> 

21: </html> 


ППИПИППППГППепа fermwithselect. рирДОДОДООО000000 
Учеб ПОДООДОДОООД00000УУе ПОДОО0000000000002 1-20000000 


| © An HTML form with checkt х À, 








< > C Q http//localhost/11/formwithcb.html || м | 


М] Tricorder 
ГІ ORAC AI 
М] HAL 2000 





011-2 000011.3000000 


0000011.4000000700000005. POST ['иѕег 1000000000 
и5егОД000001000000005 POST Гргодис 5" 1000005 POST 
г ргодисі5 ЇПДО000000220000000001 30000000000000000 
спескрохр)ОматшердооДОДОО000000000 


О0000000002 1-3000 





Reading checkboxes 


<- Q ©) http://localhost/11/send_formwithcb.php ~ 


Welcome, Jane User! 
Your product choices are: 


* Tncorder 
* HAL 2000 


П11-3 send_formwithselect. phpū000g00 


ООДОД0005ЕСЕСТОДОООООООООООООО0О0000000000000000 
ОООО000000000000000000000000000000000 


ОООДО00000000000000000РНРОДООЗООООООДО0000000000 


11.3 ОООООООЈАТМЕЦРНРЦЦ 


ОДООДОО0000000000000РНРООООООД0Н "МЕДООДООДООООО 
ОО0О0000000000000000000000000000000000000000000000 
ОДОДОО00000ОРНРООООООООООООО0О0О0НТМЕДОООООО0000000000 
ОНТМЕДДООООООООДОО0О00О00000000000000000 


ОО0О0000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000 


000011. 5000Н МЕООДООООООО0ООО00000000000000000000 
ПОООРАРО 


00001 1.5 — ООООООЈАТМЦЈО 


: <!DOCTYPE html> 

: <html> 

: <head> 

: <title>An HTML form that calls itself</title> 

</head> 

: <body> 

: «form action="<?php echo $ SERVER['PHP_SELF']; ?>" method="POST"> 
: <p><label for="guess">Type your guess here:</label> <br/> 

: <input type="text" id="guess" name="guess" /></p> 

: «button type-"submit" name-"submit" value="Submit">Submit</button> 
: </form> 

: </body> 

: </html> 


— — — = 
ODP- @ (O @ ЫЧ O> сол + Ó) N — 


0007000000000000$_5ЕАУЕВ [РНР 5ЕСРОДООООО0ОО0О000 
ОДООДОО00000000000000000000000011.500000000000000000 
ООМуеопо0000000000000000000000000000000000000000000 
ОО0000000001.1.60000000000000РНРООП 


00004 1.6 ПІРНРПИПИП 


о N б о + GQ о = 


: <?php 


$пит to guess = 42; 
if (lisset($ POST['guess'])) í 
$message = "Welcome to the guessing machine!"; 
) elseif (!is numeric($ POST['guess'])) ( // is not numeric 
$message = "Т don't understand that response."; 
) elseif ($ POST['guess'] == $num to guess) ( // matches! 
$message - "Well done!"; 
) elseif (5 POST['guess'] > $num to guess) { 
$message - $ POST['guess']." is too big! Try a smaller number."; 


: ) elseif ($ POST['guess'] « $num to guess) ( 


$message - $ POST['guess']." is too small! Try a larger number."; 


: } else { // some other condition 


$message - "I am terribly confused."; 


2 


: 4> 


ОДб0б0000000000000002000000000420005пип бо 9че55 


ОО0000000000000000000000000000% POST ['guess'(I II III! 
ПШШПШШЦШШЦППОче55ПЦППЦПШППШШЦШШИШШЦШИПШШЦШПП$_РО5Т ['guess'] 
ООООО0000000000000000000000000000000000000000000000 
О00005. POST ['guess "ДДОООО0О003О0000 


ОЗО001 50000001... еізе її...е|5еОДОДО000000000000000 


ОООО0О00000000000000000бхчеродр0о00000001005 messa ger | 
ОООО0000000001 8000000000000000Нн T Mg 


00001 1.7 ПОРНРОДОД0О00О 


17: «!DOCTYPE html» 

18: «html» 

19: «head» 

20: <title>A PHP number guessing script</title> 

21: </head> 

22: <роду> 

23: <hl><?php echo $message; ?></h1> 

24: «form action="<?php echo $ SERVER['PHP_SELF']; ?»" method="POST"> 
25: «p»«label for="guess">Type your guess here:</label><br/> 

26: «input type="text" is="guess" name="guess" /></р> 

27: «button type="submit" name-"submit" value="Submit">Submit</button> 
28: «/form» 

29: «/body» 

30: </html> 


0000021.6022.70000000000000пипацез5. рирорО00000 
ОД0000000Умевборорооророродооробородо0О000001 120000 
ПП 


| [=] А PHP number guessing sci >x \ з 


€ C ©) http://localhost/11/numguess.php 3. 


Welcome to the guessing machine! 


Туре your guess here: 





011-4 000011.6000000 


ОООО0000000000000000000000000000000000000000000 
ОДООДОО000000000000000000000000000000000РНРООДОО000 
009998 IHTMLT] 


11.4 ПШПШ 


00000021. .60000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000 
АТМЦЈООО 


П0000питоиеѕѕ.рһра00000000000пчтодиеѕ52.рһро000 
П0000000000%пит to. оиеѕ$П0000000000000 


$num tries = (isset($ POST['num tries'])) 2 $num tries + 1 : 1; 


О0000000005пит, teres о ДООО0000000005 POST 
['num tries ПДПО0О0000000005пип, пе ОО001000000000000 
ООООО0О0000000000005. POST [пит (пес 1010 


ПОООООА T MLOKA 100000 


<p><strong>Guess number:«/strong» <?php echo $num tries; ?></р> 


О00000000000%пит _їпе5ПЦППП 


ОДОО0О000000Н TM ОДОДО0000000000000009пиут tries 0 
0000000 


<input type="hidden" пате-"пит tries" value-"«?php echo $num tries; 72"/» 


00001 2.80000000000 


00004 1.8  ОДОДОДОДО000 


о ч c Ui» о — 


0 


<?php 

$num to guess = 42; 

$num tries = (isset($ POST['num tries'])) 2 $num tries + 1 : 1; 

if (lisset($ POST['guess'])) í 
$message = "Welcome to the guessing machine!"; 

) elseif (!is numeric($ POST['guess'])) ( // is not numeric 
$message - "I don't understand that response."; 

ү elseif ($ POST['guess'] == $num to guess) í // matches! 
$message = "Well допе!"; 


: } elseif ($ POST['guess'] > $num to guess) í 


$message - $ POST['guess']." is too big! Try a smaller number."; 


: } elseif (5 POST['guess'] < $num to guess) í 


$message - $ POST['guess']." is too small! Try a larger number."; 


: } else { // some other condition 


$message - "I am terribly confused."; 


:) 
. 2> 
; «IDOCTYPE html» 


: «html» 

: «head? 

: <title>A PHP number guessing script</title> 

: </head> 

: «роду» 

: <һі><?рһр echo $message; ?></һ1> 

: <p><strong>Guess number:«/strong» <?php echo $num tries; ?></р> 

: «form action-"«?php echo $ SERVER['PHP SELF |; ?>" method="POST"> 
: <p><label for="qguess">Type your guess here:</label><br/> 

: «input type-"text" id-"guess" name-"guess" /></р> 

: «input type="hidden" name-"num tries" value="<?php echo $num tries; ?>"/> 
: «button type="submit" name-"submit" value-"submit"»Submit«/button» 
: </Тогт> 

: </body> 

: </html> 


ОО000000Опипацез52.рпрЮДОДОДОДПУУеБОДОВОДОДОДОДО 


Ммеопоо00000000000000000000000000000000000000000010 


11.5 ПШ 


ОООО00000000000000000000000000000000Нн TMOU 


ООООО000000000000000000000000000000000000000000000 


ОООО0000000000000000000000000000000000000000000 
ПОР АРОООДОООДООДООООООО00000Д00ОРАРОПпеадес  оО00000000 


П000ћеааег()00000000000000000000000000000000000 
ООРНРОДООЗООООООООО0О0О0000000000000000000000000000 
ООО000000000000000000000000һпеааег()О0000000000000 
РАРОООООООДОО000О000000000000000 


000022. .900ОРНРОООООООООООООООООЗОООО00О00020000000 
ПП 


000011.9 ОООПРНРОДОДООД0000000 


: HTTP/1.1 200 OK 

: Date: Sun, 29 Jan 2012 15:50:28 PST 

: Server: Apache/2.2.21 (Win32) РНР/5.4.0 
: X-Powered-By: PHP/5.4.0 

: Connection: close 

: Content-Type: text/html 


Ooh OQ N ~ 


ПО0оО босанопбрбобРНРООООВОООООООвОвООООвОвОцО 
0000 


header("Location: http://www.samspublishing.com"); 


LLL UU cengrats. пот ООООООДОДОДОДОООО000000 
О0000000000000000011.100003000011.80000000000009П 
else iiit] 


000011.10 Опеадег 00000 


со N O, QI + G о = 


<?php 

$пит to guess = 42; 

$num tries = (155е%(% POST['num tries'])) 2 $num tries + 1 : 1; 
if (!isset($ POST['guess'])) í 


$message = "Welcome to the guessing machine!"; 
} elseif (!is numeric($ POST['guess'])) í // is not numeric 
$message - "I don't understand that response."; 


) elseif ($ POST['guess'] == $num to guess) í // matches! 
header("Location: congrats.html"); 
exit; 


: } elseif (5 POST['guess'] > $num to guess) í 


$message - $ POST['guess']." is too big! Try a smaller number."; 


: } elseif ($ POST['guess'] < $num to guess) í 


$message - $ POST['guess']." is too small! Try a larger number."; 


: } else í // some other condition 


$message - "I am terribly confused."; 


:) 


. ?> 


: <!DOCTYPE html» 

: «html» 

: «head» 

: <title>A PHP number guessing script</title> 

: </head> 

: <body> 

: <hi><?php echo $message; ?></h1> 

: <p><strong>Guess number:</strong> <?php echo $num tries; ?></р> 

: <form action="<?php echo $ SERVER['PHP SELF']; ?»" method="POST"> 
: <p><label for-"guess"»Type your guess here:</label><br/> 

: <input type="text" id="guess" name="guess" /></p> 

: <input type="hidden" name-"num tries" value="<?php echo $num tries; ?>"/> 
: «button type-"submit" name-"submit" value="Submit">Submit</button> 
: </Тогт> 

: </body> 

: </html> 


Повроооон Обе lse ППП TED ODE ce ng rats . hem ETE TETETETCIE] 


ОД00000000000100ОехіодророббобОО0000000000000 


11.6 ШШШ 


ОДОО0О0000000000000000000000000ЕК6-ппанородддо00000 


ОООО0000000000000000000000000000000000000 


11.6.1 таб 0000000 


О0000000плай СОД0О00000000РрИ p «ПП DIO HOHOHOUOULLI 
ОДОДО0О00000000000РрЙр.іпіб000000000 


[mail function] 

; For Win32 only. 

; http: //php.net/smtp 

SMTP = localhost 

; http: //php.net/smtp-port 

smtp port - 25 

s For Win32 only. 

; http: //php.net/sendmail-from 
;sendmail from = теёехатр1е. сот 
; For Unix only. You may supply arguments as well (default: "Sendmail -t -i"). 
; http://php.net/sendmail-path 
;sendmail path = 


ОДОДОДУМі пасом е УеБООДООООО000000000000пай 0000 
ООООО000000000000000000000000000015РОСОООООО00000000 
IILI IEarthLink[I[Iphp.ini[ О000000000 


SMTP = smtp.yourisp.net 


010000000 $епатай РопбД0000000Ргопо 0000Е2-плаїї 0000 
ООООО000000000000000000000000000000 


sendmail from = youraddress@yourdomain.com 


ООММі паом'бОДОПД0ОООО000О0000000Е2планодоодороодод 
ООДОД0000000Орпріпї005М ТРОДОО 


брммеь роррдбробііпих/ (о МІХОДОДООДД0000ОД5епалтаї 0 
О00000000000000000005епатаїї раєирддродО5епатаїї -t-i[]] 


000О5епаптанодоророброброророоророророоророрордоороооро00 
0000000 


sendmail path = /opt/sendmail -odd -arguments 


ООДОДОДОРА p rmi TED ED EDO EIC TW e B II IILI III I! 


11.6.2 11111 


0000011. .11000000000000000000000н6 7МЕОО00000 
тееабаск. пет 10000000 $епатай!.рирПасНой ППОПОПИ000 
ОДгееабаск пєті00000000080009000000Опатедоордо0001000 
0110000000Етаро000000001200013000000000000000000 


000011.11 0000000000О 





«IDOCTYPE html» 

<html> 

<head> 

<title>E-Mail Form</title> 

</head> 

<body> 

«form action="sendmail.php" method="POQST"> 


со N nab Wh = 


<p><label for="name">Name:</label><br/> 

9: <input type="text" $17е="25" id="name" name="name" /></p> 

18: <p><label for="email">E-Mail Address:</label><br/> 

11: <input type="text" size="25" id-"email" name="email" /></p> 

12: <p><label for="msg">Message:</label><br/> 

13: «textarea id="msg" name="msg" со15- "30" rows="5"></textarea></p> 

14: «button type="submit" name-"submit" value-"send'»Send Message</button> 
15: </form> 

16: </body> 

17: </html> 


LICIDEIDI EIE DIETE CL feed ba ck питіЮДОДОДОДОДОДОДУебОООДО 
ОДОД0000УУерооро000000000000000011-5 000000 





| qp E-Mail Form МЕ 
€ с http:;//localhost/11/feedback. html з, 





[11-5 ДО0011.1100000 
ООО0О0000000000000000000000 


11.6.3 [| III 


О0000000001.1.40000000000000000000000000000000000 
011.12000000000000000000000000000Е-та!00 


000011.12  ПОДО00000 


1: <?php 

2: //start building the mail string 

3: $msg = "Мате: ".$ POST['name']. "An"; 

4: $msg .= "E-Mail: ".$ POST['email']."in"; 

5: $msg .- "Message: ".$ POST['message']. "An"; 
6: 

7: {{ве% up the mail 

8: $recipient = "you@yourdomain . com" ; 

9: $subject = "Form Submission Results"; 

10: $mailheaders = "From: Му Web Site <defaultaddress@yourdomain.com> in"; 
11: $mailheaders .- "Reply-To: ".$ POST['email']; 
12: 


13: //send the mail 

14: mail{$recipient, $subject, $msg, $mailheaders); 

15: 7> 

16: <!DOCTYPE html» 

17: «html» 

18: «head» 

19: <title>Sending mail from the form in Listing 11.10</title> 
20: «/head» 

21: «body» 

22: <p>Thanks, <strong><?php echo $ POST['name']; ?></strong>, 


23: Тог your message.</p> 
24: <p>Your e-mail address: 


=>. <strong><?php echo $ POST['email']; ?></strong></p> 

26: «p»Your message: <рг/> «?php echo 5 POST['message']; 7» </р> 
27: </роау> 

28: «/html» 


0022100026000000005 POST Гпате 1П% POST Гета! J[] 
$_POST ["'теѕѕаде'ООО000000000000000000000% РОѕЅТОО00 
ООООООДО000000000000000000000000000000000000Е26ппаїооп 
ПОООДОО0000000000000000000000000000000000000000000 
О00000п)0 


[030005 ПОВИ$ ms g ПОДООООООООДОДООД0О00000000000000 
ОДОД0О00000000Е2-плаї0000000040005005 ms g IILI III 
LC 290000 


О8000900000000000000000000000000000000000000 
уои©уоигаотаіт.сотО000000000000000000 


[0190001 2000000000000Ргопа:ДКеріу-єо: ОООО0О0000000 
Ргого:ПОДООДОООО000000000000000000000000 


паї  ОДОДОЗООДО000О00000000000000000000000000000 
ООО0000000000000!0000000000000140000 


0000000000005епатаїт. риродоДООООООДОДОУУеьОО0000 
О00000Меоооо00000000000000000000000000000000000000 
022-6000000 





ҮП Sending mail from the forn 
€ С! ©) localhost/11/sendmail.php а 
Thanks, Jane Doe, for your message. 
Your e-mail address: jane(@doe.com 


Your message: 
I think your site is great! I will visit аташ soon. Also, can I have a pony? 


011-6 ПП sendmail.php[]LLLIL 


ОДОД00000Е6-пайроброброророб00000000000011-7000 








(а Gmail - = Submission R : : \ 


| € C B һирѕ// 'ai.googlecom/mali/A "uz 2&ik- (-201412efd3&vi WY ` 


См а i || Julie Meloni <jcmeloni@gmail.com> | 


| Form submission Results 


|. My Web Site <defaultaddress@yourdomain.com> 
| Reply-To: jane@doe.com 
To: jemeloni@gmail.com 


Sun, Jan 29, 2012 at 2:37 PM 








| Мате: Jane Doe 


| E-Mail: jane@doe.com 


| Message: 1 think your site is great! | will visit again soon. 


Also, can | have a pony? 
































011-7 sendmail.php 000 


ОООО0000000000000000000000000000000000000000000 
ОО0000000000000000000000000000000000000000амаѕсгірі 
ОНТМЕ5ОДОООО 


11.6.4 [][IHTMLTYI ЦИП 


ООН "МЕДОООООДОООООО000000000000000000Н FM EL TET 
mail  ООД00000000000011.12000000000011.1300012014000 


180190000000 
000011.13  О0000000---НТМІД 


<?php 

{istart building the mail string 

$msg = "<p><strong>Name: </strong> ".% POST[ 'name']."</p>"; 
$msg "<p><strong>E-Mail:</strong>  ".5 РО8Т|'єтаї1')."х/р»"; 
$msg .= "<p><strong>Message:</strong> ".$ POST['message']."«/p»"; 


{//set up the mail 

$recipient = "уоиёуоигаотаіп. сот" ; 

$subject = "Form Submission Results"; 

10: $mailheaders = "MIME-Version: 1.@\r\n"; 

11: $mailheaders .= "Content-type: text/html; charset=IS0-8859-1\r\n"; 

12: $mailheaders "From: Му Web Site <defaultaddress@yourdomain.com> Ап”; 
13: $mailheaders "Reply-To: ".$ POST['email']; 


со N O, € + оо о = 


со 


15: //send the mail 

16: mail{$recipient, $subject, $msg, $mailheaders); 

17: ?> 

18: <!DOCTYPE html» 

19: <html> 

20: <head> 

21: <title>Sending the Simple Feedback Form - HTML Version</title> 
22: </head> 


23: «роду» 
24: «p»Thanks, <strong><?php echo $ РОЗТ| пате |; ?></strong>, 
25: for your message.</p> 


26: «p»Your e-mail address: 

2f: <strong><?php echo $ POST['email']; ?></strong></p> 

28: «p»Your message: «br/» «?php echo $ POST['message']; 7» х/р» 
29: </body> 

30: </html> 


ПОЗОДОЗООДОО00000000Н 7М100000000001000011000000 
MIME Мег5іо пДД0001.0ПОСопеепі-сурепоОДдо0000150-8859-1П 
техі/піптІООДОООНТМІЕДООДООДОООО0ОДОД0О00000НТМА00000 
000011-800Д 





шы ЕТ = а ү 





і Gmail - Form Submission F > \ T 


| | & https;//mail.google.com/mail/?ui-2&ik-20f412efd3&vi yg | “А, | 


| C 
| | Ma і | Julie Meloni <]сте!опї@дтай.сот> | 
| by Ок vale | | 


Form Submission Results 
| 1message | 
| Му Web Site <defaultaddress(@yourdomain.com=> Sun, Jan 29, 2012 at 3:09 РМ 

Reply-To: jane@doe.com | 
| To: jemeloni@gmail.com 
| Мате; Jane Doe 


| E-Mail: jane@doe.com 


Message: Wow, HTML output in an email? So cool! Now | want а unicorn. 
























































011-8  000011.13000Е2- паї! 


11.7 00000 
ОбО00000000000000000000000Умеб о об000000000РНРОГ 
000000000000002НР000000000008 


ПППППИПИПП9, ИКЕ ПППППИПИПИППППИПИПИПИППППИПИПГ 
ОО000000000000000000000011-10000000000#!еиріоааро000 


О000000000 
1111 00000000 


$ FILES["fileupload"]["^name"] | 00000000 


% FILES["fileupload"] 


/tmp/phprDfZvN 
[“tmp пате” ] 


$ FILES["fileupload" ]["size" ] ППППОПИПППП 
$ FILES["fileupload" ]["type"] _ 


ОООО0000000000000000000000000 


11.7.1 (ПП 


ООООО000000000Н77МЕДООООООО0ОО00Н МЕДДОДОООООГ 
ЕМСТУРЕПОП 





епсфуре=" ти траг /Тогт- дата" 


РНРППППИПИИВПИИППИППИППИПИПИИПИПИИППППППИП 
MAX FILE 51Г2ЕПООООООООО000О00000000000000 
MAX FILE SIZE ПОПИОПОВОИООНОВОВОВ php.ini 000 
upload max Піезіге ПДДОДОДОДООДОДОДМАХ FILE SIZEQQOUU 
ПППППППИПИППППИППТҮРЕГПІ Те” [TN PU ТООООДОДООД0000000 
О0000000001.1.1400000000000НЙ7мМЕ000000 


очком = 


000011.14 ПИПИПИППИПІ 


: «IDOCTYPE html» 
: «html» 


<head> 

<title>A simple file upload form</title> 

</head> 

<body> 

<form action="do upload.php" enctype-"multipart/form-data" method="POST"> 


: <input type="hidden" name="MAX FILE SIZE" value="1048576" /> 

: <p><label for="fileupload">File to Upload:</label> 

: «input type-"file" id="fileupload" name="fileupload" /></р> 

: «button type="submit" name-"submit" value="send">Upload File</button> 
: </form> 

: </body> 

: </html> 


ОО00000000 ё 00000000000 4 мвровооовоооноо 


fileuploadL Д0100О000000000000000001ч1еийріоаа пітіДОДД000 
ОД0000УУСБОДООДОДОДОДСУУевьо орооб0000000022-9000000 


шиқ Р "m 
[5] LC 
| АЕ | 


/ [=] A simple file upload form х \ а 





< Q © http://localhost/11/fileupload.html ~ 


File to Upload: | Choose File | Мо file chosen 


Upload File 


[11-9 000011.14000000 


00000090 иріоаа.рһпео0000000000000 


11.7.2 [jJ IILI! 


[000000000000$_РАЕЕЗОПИОВИНИВОВОООНООВОВОСОВООВОВ 


ОО00000000001.2.15000000000000 


со + O) о + OQ N — 


000011.15 О0000000 


«?php 
$file dir = "/path/to/upload/directory"; 


foreach($ FILES as $file name => $file array) í 
echo "path: ".$file array[ Ттр name']."<br/>\n'; 
echo "name: ".$file array[ пате ]."<рг/>1п"; 
echo "type: ".$file array['type']."<br/>\n"; 
echo "size: ".$file_array['size']."<br/>\n",; 


9: 

10: if (is uploaded file($file array['tmp name'])) í 
113 move uploaded file($file array[ tmp name'], 
12: "$file dir/".$file array['name']) 

18: ог die ("Couldn't move file"); 

14: echo "File was moved!"; 

15 ) else ( 

16: echo "No file found."; 

14: ) 

18: } 

19: 2» 


0000011.150000000020000511е аїгГорД0О0000000000000 


ОООДО0000000000УУевпорООДОДОРеЕєрабмлмму nobody lt 
00000 


02000000000 Ча чх/ УМ ХООЕМИтаом ООООО0ОО00000000000 


$file dir = “C:\Users\You\Desktop”; 


ПА00000ғогеасћ000000%_ БИКЕЭППППИППИППППИППИПТГІІ 
О00#000000000000000000000000000000400ғогеасһо00000 
00000%#е патерО00000000000%#!е_аггауроо0000000000 
ОО0000000000000 


ООО0000000000000200000000000000000000000010000 
іѕ иріоааеа ће()О00000000000000000000000000000000000 
ООО00000000000000002чевророододроорооооооо 


ООО00000001 10001 000000000000000000000000000000 
move uploaded #іе()00000000000000000000000000000000 
000015 uploaded ћ!е()0000000000000томе uploaded file()[] 
ПОДО00000000000000000000000002мерроооорбб0бор0000000 
р0000000таїзеб 


О00000000000Мас О5ПУ/ пасм в ПОДООДОООДОДО000000000 
ООООО0000000000000000000000000000000000000000000000 
ULL] 


Об0000000030д0 uptead.ph pri ib bib b b i dO Web E 
О000000%Уеюроо000000000000000000000000000000000000 
11-10000000 





localhost/11/do upload.ph 
€ С ©) http;//localhost/11/do upload.php EN 





path: C^Users JM AppData Local Temp php 
пате: IMG 20101107 131718 Jpg 





[11-10 00001 1. 1400000 


11.8 || 


ОО0О00000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 


00000000 


ОООО00000000000000000000000000000000000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
ОДОДОО0ЕплайроДоо0ДООбОДООООРНРерОДОУ/евЛОЗОДОД 


11.9 Q&A 


ОбОООООО0000000000000000000000000000009820000 
НУО 


АПОДОДОО000000000Сбосдіе рДрорОДОООООУ ВЕОООДОДОДОП 
1000“ спеезе"ДОДОДОДОПООО0УАВІО) 


https: //www,. google.com/#hl=en&cutput=search&q=cheese 


ООДОО0О0000С E TORU P 9S ТОООООООООО0ОО000000000000 
ОООО00000000 output III IILI IILI а О00000ачегуби 


“cheese” ПДОДДІМРЮТОДООООО 
ОПОДОДОДОДОД00000000 


АООООДОООООО0ООО00000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО000000000000000020МмвородороодрродророорродорО000 
З350КВОДО ОДОО00О0000000000000000000030МАХ FILE SIZET] 
upload max ПіезігеПріир.іпіІОДООДОООООДОДОДОДОДОДО 


11.10 ПП 


ОООО000000000000000000000000000000000000000 


ӨШ 


ТОО00000000000000000 

2 ПОООД000000000РОЗ5 ТООООООО00000000 
ЗОДОДОД0000000000000000000000000 
40 О0О000000000000000000 

з Опайоороро040000000 


6 ООООО00000000000000000000000000000 


ЕШ 


10005 SERVER['PHP БЕГ Р ЈПОПОООООО 
205 РОЗ ТОДОДОП 

305 РІГЕЗОДОООД 

АППП0 (оса опПћеадег )ППО 
ЗОДО000000000000000000 


ЄОООООД000000МАХ FILE SIZETIIIDEIL 


ӨШ 


ТООО0О0000000000000000000000000000000000000000 


2 10000 О00000000000000000000000000000 


[1120] []]Cookte[] I I I| 


ОО00000000 


ПО00000соокіеПП 
[000000000000000 
бОб000000000 
ОО00000000000 
000000000 
[00000000000 


PHP П000000000000000000000000000 cookie [II IILI I II! 
О00000 РНР О0000000000000000000000000000 


12.1 Cookie 


О0000РНРОО0000соокіеВоОО000000000000соокіер00000 
ООООДО0000000000000000000000000000000000000000000000 
20[]cookie[ ПДсоскіедП ОДОДОДО00000000000000000000с00кіе 
LICIDCIDEIAKBIE] 


ППППсоокгег ПДОДООО00000000000000000000000000000000 
ОООО0000000000000000Осо0кіеудд00ООсооктерр000000000 
ООООД00000000000000000000000000 


12.1.1 ||1 ПППсооКкге 


ППППсоокегРНРЦИПППИППИИПИПИП 


НТТР/1.1 290 ОК 

Date: Wed, 18 Jan 2012 10:50:58 GMT 

Server: Apache/2.2.21 (Unix) РНР/5.4.0 

X-Powered-By: РНР/5.4.0 

Set-Cookie: vegetable-artichoke; path=/; domain-yourdomazin,com 
Connection: close 

Content-Type: text/html 


П00000005её-СоокіепрО00000/00000000000000000 
ехрігаїїопП ПООДО00000000007007 cookie iip p D D I II! 
ОООО00000000000000000Осос0кіер 0000 


раї 9аотаіт000000раћ09отаіћ00000соокер 
ПООО0000000000000000*/" 000000000000 cookie [I III III] 
ПЦПЦППШШПППШП“^/ргодисї</”ПЦЦПсооКеПППП\/еБЦППЦП/ргоаисї5[[П 
ПИПШШШШШП 


domain ППППППИП cookie 0000000 Internet ПДОООООДООО0 
умууми уоигйаогпа!п.сотПЦЦЦЦуууууу. уоигаота!п.сотЦЦсооКте[ 
йоташ[ЦПЦЦППЦПЦуууууу.аота!п.сот ПППсооке ПООООООООООЦ 
00000000000000Оуумуу2 .аопаїп.согадрійпа.дотаїп.сопа UL 
бОО00000000000000Осо0кіе [III LIL IILI cookie 0000 domain 
ООООД0000000000000. аотаїп. co m ЮДОДОДПОДОООДОСООО 
соокіерПрДОр000000000000Осо0кіепрд00000000Осоокіе р 00 
ООО00000000У/Уеьб0р000000Осо0кіед ] 


12.1.2 [l[cookies 


Дрммерр00000О соокіедд)000Осоокіе i ООДОДОДОД00000 
ПППППППсоокеП n i n iD eee rer I ab bp p m ETE 
00000 


GET / НТТР/1.0 
Connection: Keep-Alive 
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.7 (KHTML, like 


Gecko) Chrome/16.0.912.75 Safar1/535.7 
Host: www.yourdomain.com 


Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, image/png, */* 
Accept-Encoding: gzip 

Accept-Language: en,pdf 

Accept-Charset: iso-8859-1,*,utf-8 

Cookie: vegetable-artichoke 


ПООПОРНРИПОО О ОО сооКкіеПсоокіепПДОДОНТТР СООКЕПППП 
05 СООКЕПППППИППИПППИПППИПЗППИПППППГІ 


echo $ SERVER['HTTP COOKIE' ]; || will print "vegetable-artichoke" 
echo getenv('HTTP COOKIE'); // will print "vegetable-artichoke" 
echo $ COOKIE[ vegetable']; // will print "artichoke" 


12.2 РНР cookie 


О00000000000РНРО000000соокіер0000һеадег()00000 
ѕе-Соокіећеаадег()00000000000000000000000000000000 
О0000000000ћеааег()О000000000000000000 


header("Set-Cookie: vegetable-artichoke; expires=Thu, 19-Jan-12 14:39:58 GMT; 
path=/; дотаіп=уоигаотаіп. сот"); 


О00000000000О ee кіеПрОб0ОПОО0000000000000000000000 
ОООО00000/0000 URL ВО0000000000000000000000000РНРО00 
П00000005еёсоокіе()] 


ѕеёсоокіе()О000000000000000000000000 Set-Cookie ППП 
ПООО0000000000000000000000000Ос00кіепдОсоокіепр міх 
ПООО0000000000000000000Осо00кіеподрооророордрорборорооо 
00 1000000000 сооке[0000000000000000000 


100012.1005еісоокге( ОППППППсоокгеп 


000012.1 ПО00000соокіеП 





: <?php 
: ѕеїсоокіе( "vegetable", "artichoke", Жіпе() “3600, "/", ".yourdomain.com", 6); 


: if (isset($ COOKIE[ 'vegetable'])) í 

echo "<р>Не110 again! You have chosen: ".$ COOKIE['vegetable'].".</p>"; 
:) 
} 


E 2> 


else í 
echo "<p>Hello, you. This may be your first visit.</p>"; 


о о +O) GI + €) N — 


ОДО00000000000000Осор0окіе 0020005. СООКІЄ | 
vegetable’ ІПДОДОО0О000000000000000О соокіедроо0000000 
ОООО000000000000000000000000000000000 


ПППП?ППсоокеППППП vegetable” ]cookie| HL] 
[]artichoke"[][ time 0000000000000000000 360000000 
3600 ДОДОДОООДОДОО0О0000000000007/ 0000Осоокіеррр00000 
00000000000Одоплаї 00000". уочгаотат.сота [III I I III! 
ПОО000О0000оса!һоѕєО0000соокіео00000000000000000000 
Пѕеёсоокіе()О000соокіе$ПП000000000000005еїсоокіе() 000000 
ООДОДОДООО00000000000000000000 


П ѕеёсоокіе()0000000000000000 O О000000000000000000 





ППЦсооК!еПППШИШПППШПППШШППШИШПП12.1ППШППИШИШШШШШШШШПАрасһеПРНРЦПШШП | 
О000000000000000000000000000000000000000000000000соокіер | 


ОД000000У/ев ОО0000000 соокіер012-1000000012.10000 


cookie[T ]L]cookter E ПООДОДОДО0Д00Д00000000000000000000000 
000000 





[5] localhost/12/setcookie.php > / ~ Options - Cookies and Oth 


= С! | © chrome//settings/cookies ү 4 


Options J Ч Cookies and Other Data ] 


Site Locally Stored Data Remove АП | |З» localhost x 
Pr Со 
Basics localhost 1 cookie 
Personal Stuff xis 
На | Мате: vegetable 
И ا ل‎ DL Ls Content: artichoke 
аю Оотаіп: localhost 
Path: / 1 
Im; send Far: Any kind of connection 
Accessible to Script: Yes 
Created: Wednesday, January 18, 2012 10:57:11 AM 
Wi Expires: Wednesday, January 18, 2012 11:57:11 АМ 
Cc 
Remove 
Ја! 
T BEEN 
4 її | 


012-1 000 Web П00000000соокіе 


ПППППСООКтеППЦПППППП5$есооКкте()ППППППППИППП 
http://www.php. net/setcookie ПРНРЦЦП 


[cookie 


ППШПЦШПШШП соокіер0000000 cookie 00000 setcookie O00 
ШІ! 


setcookie("vegetable"); 
ОООООД00000000000000000000000000Осо0окіерродо0000 
ПО000000соокіеро000000000 


ѕеїсоок1іе{ "vegetable", "", time()-60, "/", ".yourdomain.com", 0); 


П0000005ѕесоокіе()00000соокіепо000000000000000000 


12.3 ПШПШ 


ОООО00000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ПОООДО00000000005 SESSION ОДООО00000000000 


ОДБОДОД0000000000000000000000 
session set save Пап Мег()ППИПППИОПООД 
session set save һапаіег()О000000000000000000000000000 
ОООООО0О0000РНРеОДОДООООДОООООДОДОДОДОДОД00000 


12.4 ШШ 


ОООО0О00000000000000000000000000р0р.п1000000000 
ОО000000000000000000000000000000рһр.іћі000000000000 
ОДОД010000000УУео0о0 


session.auto start = 0 


1005еѕѕіоп.аиёо_ѕёагОО1000000000000000РНРО00000 
ОО000000000000000000005ез5іоп start OT TTE] 


ОО0000000000000 ѕеѕѕіоп 1ФО0О00000000010Пбевззіоп та () 
ОДОООО0000000001000000 12.2 ПОООООО0О00190000000 


000012.2 000000000 


: <?php 

: session start{); 

: echo "«p»Your session ID is ".session id().".</p>"; 
x d 


+ о N — 


ОДООО0000000000000000002005ез5іоп 5кагЕ0ПОДОДО00000 
ТООООООО0000000000000000000790000000000000000000000 
ОсоскіедпрДорДОДОб0000000000000000000 


Your session ID is 8jou171in51d@8e5onsjkblesi6. 


ОООО000000000000000000 


Your session ID is 8jouli7in51d68e5onsjkblesíe. 


О000000000Осоокіерро01200000 


ОО00000000000000005агё session 000000Осоокіепооро00 
ООООДО0000000000000000000000000000000000000000000000 
ПП 


ПО Web 0000000000000000О000ООО0О0ОООоООООсоокепооО 
ПППППППрһр.іпіП ІП вессіоп.сооКкіе Шештледрророоооооо0ооОо 
ПОООООО000000000000000000 


12.5 ОООООЦ 


ПИПИРНРПППИПППИПИИППИППИППИППИППИППИППИППИППИПІ 
00005. 5Е5510МПОООООДО0ДО000ДО000000000000000 


000012.30000005 SESSIONTTEJLILILIEILIpreducti[]product2 
0030004008 


000012.3 [HII] 


: <?php 


1 

2: session start{); 

3: $ SESSION['producti'] = "Sonic Screwdriver"; 
4: $ SESSION[ 'product2'] = "HAL 2000"; 

5: echo "The products have been registered."; 
б: 7» 


ОДОООО000000000000007 2. О00000000000000007 2-400 
ОООООРНРООДОДОООО000000005. 5565510МПД000 


000012.4 100000000 


: <?php 

: session start{); 

2> 

: <p>Your chosen products are:</p> 

: <ul> 

: <li><?php echo $ SESSION['product!i']; ?></11> 
: <]1><?рһр echo 5 SESSION['product2']; ?></11> 
: </ul> 


со) N O, сл + aN = 


112-2 П00000000 12.4 0000000000000000000000000000 
$ SESSION | 'product1' ][|S SESSION | 'product2' 1100 





[5] localhost/12/getfromsessic 


4 "Tx LG. ГІ Ih ізі 'aetfrc A. LL 
лийаш. pen ктү д FETT лит а Ei реч ПІР” 
(> к», [ IL L H uf f оса Ost, La Ч с Lit к Е | 1.5 с. ыз | Li і 1 П HI IH 





012-2 ОДОДОДОПО 


ОООООООО00О0000000000000000000000000000000000РНРП 
ППИПИПИПИПИПИП Пвессіоп save. path 0ПДОД0О0000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ОООО000000000000000000000000000000 


echo session save path(}; 


III Emp TEJDIDEIE Aem РООООООООООО000000000 


sess Та963е3е49186764р0218е8240504е7р 
sess 76cae8acli231btlaTa2ce69935c11dd95 
sess bb50771a769c605ab77424d59c784ea0 


ОДО000000000 12.2 ПО00000000000 10 ООООО0000000000 
0000000 


producti|s:17:"Sonic Screwdriver";product2|s:8:"HAL 2000"; 


О0000005. SESSION ОПОДООДОРНРОООООДОООДОДО0О0000000 
ОООО00000Д000000000000000000000000000005. 555510 М/000 
ООООДО0000000000000000000000000000000000000000000000 
О00000005. SESSTONT| 


000012 .З0000000000000000005, 5565510 МОООДОДОДОО00Д 
ООООДО0000000000000000000000000000000000000000000000 
00000000О5епіаїіге ОППООД000000000 


00002.2.50000000000000000000000000000000000000000 
00000 


00001 2.5 ПОООООО00000000000 


1: «?php 

2: session start(); 

З: Y» 

4: «IDOCTYPE html» 

5: «html» 

6: <head> 

7: <title>Storing an array with a session</title> 

8: </head> 

9: «body» 

10: «hi»Product Choice Page</h1> 
11: <?php 

12: if (isset($ POST['form products'])) í 

13: if (lempty($ SESSION['products '])) í 

14: $products - array unique( 

151 array merge(unserialize($ SESSION[ products 1), 
16: $ POST['form products'])); 

17: 5 SESSION['products'] = serialize($products) ; 
18: ) else { 

19: $ SESSION['products'] = serialize($ POST['form products']); 
20: ) 
21: echo "<p>Your products have been registered!</p>"; 
22: | 
23: ?> 


24: «form method-"post" action-"«?php echo 5 SERVER['PHP SELF']; ?>"> 

25: «p»«label for-"form products"»Select some products:</label><br /> 

26: «select id-"form products" name-"form products[]" multiple-"multiple" 
size="3"> 

27: <option value="Sonic Screwdriver">Sonic Screwdriver</option> 

28: «option value="Hal 2090">Hal 2000</option> 

29: <option value="Tardis">Tardis</option> 

30: «option value="ORAC">ORAC</option> 

31: «option value-" Transporter bracelet">Transporter bracelet</option> 

32: </select></p> 

33: «button type="Submit" name-"submit" value-"choose"»Submit Form</button> 

34: </form> 

35: <p><a ћгет="5е551011.рћр">до to content page</a></p> 

36: </body> 

37: </html> 


00000020 О5еззіоп, start OLI pp pp E EET CD CT TL 
О00000000024000009ТтМЕ00002600000000ғогт_ргодисѕ [1 
ПБЕКЕСТОООПОООООООЦОР HO NE TET 


ППППН ТМЕИПППППИПИППИПИПИПГПППГПГГМАМЕГППИПИППППИПИПИППИПИППППИПГП | 


001 10000ОРНРООДОД0000005. POST [ 'form_products' ПІДП 


000 12 00000000000000000000000000000000000000 
$ SESSIONDO 


О00001.200000005. SESSTON [ ‘products’ ІПООООО0О00000 
ОДОО0О00000000000000000000005 POST [ 'form_products' Щ 
ООООД0О000000000000005ргоднсвь0000140001 6000000001 7 
[L|] products[ [I EIS. 5ЕББОМПППИПІ 


Lj 35 ООДОООДО000000000000000000000000000000000000 
П 12.6 ОДООДОДО00000000 12.5 ППППППаггаувессіоп.рһрП 


00000002.2.60000000000000000000000Даттаузеззіоп.рпр 
00000 


000012.6 ШШШ 


очагом — 


: <?php 

: session_start(); 

: 2> 

: <!DOCTYPE html» 

: <html> 

: <head> 

: <title>Accessing session variables</title> 
: </head> 

: <body> 

: <hi>Content Page</h1> 

: <?php 

: if (isset($ SESSION[ 'products'])) í 


echo "<strong>Your cart:</strong><ol>"; 
foreach (unserialize($ SESSION['products]) as $p) 1 
echo "<li>" Spo SFI; 


echo "</ol>"; 


: ) 

. 2> 

: <p><a href="arraysession.php">return to product choice page</a></p> 
: </body> 

: </html> 


00000000 2 ПППвессіоп (аг ОО0000000 12 0000 


$ SESSION | ‘products’ 1П000000000000000000000000 14 000 
16ПОООО0О00000000000000002.2-зОО00000000000 





Accessing session variables 


= С ©) http://localhost/12/session1.php x, 


Content Page 


Your cart: 


1. Tardis 
2 ОКАС 





012-3 ОДООО000000 
ОООО00000000000000000000000000000000000000000000 
ОДОО000000000001 2.5000002.2.6000000000000000000000000 
00000000 


12.6 [JHI I! 


00000О5ез5іоп destroy ПОДОДОО0000000000000 
ѕеѕѕіоп_деѕігоу()ОП0000000000000000000000000000000000 


ОО0О000000000 


session startí); 
session destroy(}; 


ОООО00000000000000000000000000000000000000000000 
ООО0000000000000 


ПППвессіоп аесігоуО ПП пп ИП 
ѕеѕѕіоп_деѕігоу()000000000000000000000000000000000000 
ОО00О0000000000000сеѕ ООООООООООООО5000000000000000 
000000 


session startí); 

$ SESSION['test'] = 5; 

session destroy(); 

echo $ SESSION[ test']; // prints 5 


ОООО00000000000000000000000000000 


session start(}; 

$ SESSION['test'] = 5; 

session destroy({); 

unset($ SESSION[ 'test']); 

echo $ SESSION[' test']; // prints nothing (or a notice about an undefined index) 


12.7 ПООООДОО0О00000000 


ОООО0О00000000000000000000000000000000000000000 
L 0О0"ОО00000000000000000000000000000000000000000000 
0000000 


12.7.1 1000000 


ОООО00000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ООООД0000000000000000000000000000000000000000 


ОООО00000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
DEP ОООО" ОО000000000000000000000000000000000000000000 
ООООД00000000000000000000 


12.7.2 [ШП 


ОООО00000000000000000000000000000000000000000000 
ООООД0000000000000000000000000000000000000000000000 
ОООО000000000000000000000000 


ОООО00000000000000000000000000000000000000000000 
ООООДО0000000000000000000000000000000000000000000000 
ООООООО0О0000000000000000000000700700000000000000000 
ООДОО0000000000000000000000000005. 5Е5510МПОДОДО0000 
ОООО00000000000000000 


12.8 || 


ОДООО0О000000000000000000000000000900Осо02кіе 00000 
О000000000000000000000соокіеп00000000000000000000000 
ОО000000000 


П000000соокіепрО00000000000000000000000000000000 
ОО0ОДО0000000000000000000000000000000000000000000000 
000000 


ОО00000000000000ПО5еззіоп 5сагООООД00000000000000 
О0000000005. 5565510МДОДОДОДО0ОО0ООДОДО0О0000000000000 
00000 


12.9 Q&A 


орр000000Ососікіедорооб000000000 


АПОДООООО0000000000 соокіеро0000 соокіербо00000000 
ООДО000000000 соокіе000000соокіерообо000000000"000"00 
000000 соокіепрО00000000000000000000000000000000000 
соокіеЂ0000соокіерПООО00000000000000000000000000 


ОПОООО0О000000000000 
АДОДОД0000000000000Осоокіе ОДДООДООООО0ОДО00000000 


ПОООО000000000000000000000000000000000рһр .ті000 
session.use соокіе5сі | ПОППППсоокеП 


12.10 |ІІІ! 


ООООО00000000000000000000000000000000000000 


ӨШ 


10000000000РНРОО0000000000 
2 10000000000000 21 


ЗОПООД000000000000000000 


ОЦ 


100000900000О5ез5іоп start OL iid ibn 
210000005еѕѕіоп (а ОПООООООО ТФ 


3Usession_destroy()QUU000U0000000000 


ӨШ 


1ОрООО000000000000000000000000000000 


2 ПО00000000000000000000000000000000000000 


0130 ДО00000 


00000000 


ООО00000000000000 
ООО000000000000 
ОО0000000000 
ОО00000000 
ООО00000000000000 
00000000 

0000000 
ООО0000000000000000 
П000ѕһе 000000000000 


ОДООДОО00000000000000000000000000РНР IILI III II II 
ОДОООО0000Д0000000000ОРНРОАраспермуз обрророророр 
ООООО00000ОРНАРОООДОООООООООООООООООО0ООО000ОРНРОДООДОДО 
HOOLI 


13.1 [j Include ll Ш 


псїшйаеППППППШШПШПШИПЦШППППРНРЦЦШИППРНРПППШШШПШШП 
ООО00РНРООООООООООООООООООООООООООООООООВООООО00 


ОДОД0О000000000000000іпстмагррод0ОДОО0000000000000 
ОДОО00000000000000000006бч9000000000000000000000000 
О000000000000000001пеічаеВоо00000000000000000000000 
П0000000000тутсіџае.рћробо0000000000000000000000 


пстмае ПООДОДО0Д0000000000000000000 13.1 00000000 
РАРДОДОДОДООІпсімае ПП ППТ 


000013.1 П іпсінде() 


1: <?рһр 
2: include 'myinclude.php'; 
da. ue 


00001 3 10іпсічае р0000Отуїпсічде.рарроДООООО00 
13.2 ПОООДО000000 


000013.2  00000000 1 3. 10000 


1: I have been included!! 


00000 1З3.АПППППППППТЕеві include. риРОДОООО00000 
13).2р000000000туїпсти де. ри РОДООООПО0О00О00УУеБДБОДОДООО 
ОДО0000УУеОО0ООвбезі іпсіџде.рпроб00000000000 


I have been included! ! 


ПИППИПРНРПИППИПИИПИИИППИППИППИИПИПИПИПИПППППППИП 
ППППППИППИППИПППИППИПППИРНРПИПИИПИРНРЦИПИПИПППИПІ 
О000000213.30000000туіпсіџае.рћро0000000000000000000 


000013.3 ППРНРЦИПИПИПИП 


1: «?php 

2: echo "I have been included!!«br/»"; 

3: echo "But now I can add up... 4+ 4 = ".(4 + 4); 
4: 2» 


00000 13.3 0000000000 myinclude2.php ПООООООООООЦ 
test іпстиде.рпрОДОООООДОДОДОДО00000О000000000УУебО0О0 
ООДОДО00000000УУеьбО0000безі іпстиде.ріи рОДООО000000 


I have been included!! 
But now I can add up... 4 + 4 - 8 


ООО00008000000004040000000ОРАНРОООООД000000 


13.1.1 [j IILI III 


РАРОООООООООО0000000000000000000000000000000 
геРигпПОДООООООО0000000000 НТМЕДОДОДО 13.4 00000 13.5 
ОО0О000000000000000000000 


000013.4 ДДіпсімае ДДОРАНРОДООСО 


1: «?php 

2: $addResult = include 'returnvalue.php'; 

З: echo "The include file returned ".$addResult; 
4: 7» 


000013.5 ОДОДОДО00000 


: «?php 

: Фгетма1 = (4+4); 

: return $retval; 

?> 

: This HTML will never be displayed because it comes after a return statement! 


т р № ~ 


00000 1 3. 400000000О О test. return value.phpr]i iil l 
13.5 ПОО0ОО00000геёигпуа!Іџе.рћро0000000000000%еопо000 
ОДОДО000000У/еор)00Обезі гееитма ше.рлророоооооооо 


The include file returned 8. 


0000002 3. З0500000000000000000000РНРООООДООРНРОДО 
ОО00000000000 


13.1.2 [| linclude[|||| 


О000000000000000теіоаепроо000000000000000000000 
ОО0000000000000000000теіџаепр000000 


$test = "1"; 
if ($16051 == "2") 4 
include 'file.txt' ; ff won't be included 


} 


ОДОО0О000000000іпсічае ИП ПП пп 
13.600000ғог000000псіџаероо00000000000000'псіџаер 
00000000 


000013.6 0000000псічае 


: «?php 

: Тог ($x = 1; $x«-3; $x**) ( 

$incfile = "incfile".$x.".txt"; 

echo "Attempting to include ".$incfile."<br/>"; 
include $incfile; 

echo "«hr/»"; 


} 


2> 


о 400i Р о; — 


00000 1 3.6000000000О100ру, іпсічае.риророор0000000 
УчерБ ПОДОДОД0О0О0000000000003000000іпебеї extr | 


incfile2.txt[]incfie3 х ДО ДООДОДОДО0О000000000000000000000 
00000002 3-1000 


PIT EM 
ы = Ба ылы, | 
Е | 
Ц 
E = 2 TTE J 





ч] localhost/13/loopy_include 


€ Q ©) http://localhost/13/loopy_include.php З, 





013-1 loopy іпсінде.рһрППП 


ООО000000000000000000000000 іпстчаеррдроро0000000 
00000000 


13.1.3 ||Іпсінде опсе[|| 


ОДОД0О00000000000000000000000000000001п1стмаг)000 
ОДООО0О0000000000000000000000000000іпстчаердодо00000 
ООООО00000000000000000РНРеОДОООП 


ПІ Іпсімде опсеП ПП псамаер Па 1 
include опсепдорОДОДородбордроррборророробіасічаерр0р000 
ОО0О00000000000000000000їпсіиде опсе ПП p nmi ETC 
ГІПІпсімде опсепдоооборророророророп 


13.1.4 include раһ 


[][]includeO[Jinclude опсе() 0000000000000000000000000 
ПООДООД00Д00Д00000000000000000000000000000000000000 
OOOO ПЫ ООДОООД00000000000000 


include once '/home/user/bob/htdocs/project4/lib/mylib.inc.php'; 


ООООО0000000000000000000000000000000000000000000 
О000000000000000000000000000рһр.іт0000псіџае path 
00000000 


include path  .:/home/user/bob/htdocs/project4/l1ib/ 


include ра О00000000000000000000%№1паомѕ00000 
include_path О0000000000000000000000000000000006(.)0 
LI BEBE ОООООООООООО includel] include oncer Til lbi i lEill IL] 
include ра” ППІПППП 


include once 'mylib.inc.php'; 


ОДООО000000000000 include_path ООП 


PHP О000геачігерО00000іпсічаерО000000000000геаиге | опсепобо0000000 
ООгед мігеОДОООООО0000000000000000000000000000000000000000000гедиїгеї) | 
ОО0000000000000000 x 


13.2 ПОО 


ООО0О0000000000000000000000000000000000000000000 
ООООООРНРеОДООООООООДООООО000000000000000000000000000 
ПП 


13.2.1 (Пе exists()LLLL DLL 


ПООООО е ехіѕ5()050000000000000000000000000000000 
ООООООООООООООООДОДОДОДОДОДОрО000б1е exists (DULL 
ігиегПі ППГІТаівеП 


if (file exists(' test.txt')) í 


echo "The file exists!"; 


} 


ООООО0Д0000000000000000000000000000000000000000 


13.2.2 N 


00000015 #е()0000000000000000000000000015_ АІе0000 
ОО000000000000000 


if (is file('test.txt')) í 
echo "test.txt is a file!"; 


j 


ОДОО0О000000000000000000000015. аїгОООО000000 
|5 ФІРООООО00000000000000000 


if (is dir('/tmp')) { 
echo "/tmp is a directory"; 


j 


ООО0О000000000000000000000000000000000000000 


13.2.3 LU 


ООО00000000000000000000000000000000000000000000 
ОДООДО0О00000000000000000ОРНАРОООООООООДО00000000 


is геадабіе ПОДОПООД000Д0000009 МІХОДООДОДОООДОДОО 
00000000000000000000000 S. rea dale )рооооооооооо0ооооО 
WOULD 


if (is readable(' test.txt')) Í 
echo "test.txt is readable"; 


} 


is_writable OD lb biis геадабіе ПОП 
is мигігабіе ОДОДОДО00000000000000 


if (is writable( test.txt')) Í 
echo "test.txt is writable"; 


} 


іѕ ехесиѓаріе()О000000000000000000000000000000000 
ОО0О000000000000000000000 


if (is ехесикарів( test.txt')) í 
echo '"'test.txt 18 executable"; 


} 


ОООО000000000000000000000000000000000000000000 
13.2.4 П#їеѕіғе() 0000000 


О00000000#1еѕіге()0000000000000000000000000000000 
П0ғаіѕерО0000 


echo "The size of test.txt is '.filesize( test.txt'); 


ОДООО0О00000000Е2планордрдродододророоророророородопо 
ОДОД0О000000000Е26пайодродорордооророровордооророводородро 
ОООООД000000000000000000000000000000000000000000000 
ООО0000000000000000000000000 


13.2.5 ПОООООООООООО 
LLIILIILILILILI LIL L ILILILIIILILILL ILLIPHPILIII IILI III I 


О000000бТеавбітебодООО000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
[00000000019 70010120000000000000000Часеодророр0о0000000 
ОО00000000000 


$atime = Tileatime("test.txt"); 
echo "test.txt was last accessed on ".date('D d M Y 9:1 А", $atime); 
{i Sample output: test.txt was last changed on Sat 26 Арг 2008 12:52 РМ 


ОО00000йТепєпеб ОО ООО0О0000000000000000000000000 
ОМИ'ХОДООбОО000000000000000000000000000000 


$mtime = Filemtime("test.txt"}; 
echo "test.txt was last modified on ".date("D dM Y g:i А", $mtime); 
ff Sample output: test.txt was last modified on Wed 18 Jan 2012 7:11 РМ 


PHP [JLI LI LI Песатео ОДООО0000000000 UNIX 00000608 
ОО0О0000000000000000000000000000000000000000 
ћесите()00000000000000000 


mtime = filemtime("test.txt"}; 
echo "test.txt was last modified on ".date("D d M Y gii А", $Smtime); 
// Sample output: test.txt was last modified on Wed 18 Jan 2012 7:11 РМ 


13.2.6 ШШШ 
00002 3. "ООООДО0000000000000000000000000000000 


000013.7 О000000000000000 


1: <?php 

2: function outputFileTestInfo($f) { 

3: if (!file_exists($f)) í 

4: echo "<p>$f does not exist</p>"; 

= return; 

6: } 

Ті echo "<p>$f is ".(is file($f) ? "" : "not ")."a Ғі1е</р>"; 

8: echo "<p>$f is ".(is dir($f) ? "" : "not ")."а directory</p>'; 

9: echo "<p>$f is ".(is readable($f) ? "": "not ")."геадарје</р>"; 
19: echo "«p»$f is ".(is writable($f) ? "": "not ")."writable</p>"; 
11: echo "<p>$f is ".(is executable($f) ? "": "not ")."executable</p>"; 
12: echo "«p»$f is ".(filesize($f))." bytes</p>"; 
13: echo "<p>$f was accessed on ".date( "Dd M Y g:i A",fileatime($f))."</p>"; 
14: echo "<p>$f was modified on ".date( "D d M Y g:i A",filemtime($f))."</p>"; 
15: echo "<p>$f was changed on ".date( "Dd M Y g:i A",filectime($f) )."</p>"; 
16: 


} 
17: $file = "test.txt"; 
18: outputFileTestInfo($file); 
19: ?> 


ОО000000 filetests.php 000 Web ОДОДОООООО00000 Web 
ОО000000000001 3-2000 


== [5] кеші iem 
localhost/13/filetests.php 
€ С ©) http://localhost/13/filetests.ohp З, 
test txt 1s a file 
test txt 15 not a directory 





test txt 15 reada 
test txt 15 writable 

test txt 1s not executable 

test txt is 34 bytes 

test txt was accessed on Sat 26 Apr 2008 12:52 РМ 


fied on Wed 18 Jan 2012 7:11 PM 





test txt was пи 


test txt was changed on Sat 26 Apr 2008 12:52 PM 


[13-2 filetests.php||[ [| 


ОО0О000000000000000000000000000000000000000000 
00000002 3. 70070000 


echo "«p»$f is ".(is Tile($T) ? "" : "not ")."а file</p>"; 


0000 15 #е()00000000000000000000иероовбоооо00000 
ОО0000007 not ООО0О000000000000000000000000000000000 
ОО0000000000 


$1$ it = is file($f) 7 "" : "not ' 
echo "«p»".$f." is '.$is it." a Тіїех/р»"; 


ООО000000000#1000000000000000000000000000000000 
ПП 


if (is file($f)) í 
echo "«p»$f is a Тл]е</р>"; 
| else 4 
echo "<p>$f is not a file</p>"; 


} 


ОДОЗОД00000000000000000000000 


13.3 MMM 


ОДОООО000000000000бо0чсб ОООООД00000000000000000 
соиспПОООДб0Д0000000000000000000000000000000000000000 
ОО000000000000000 


touch( myfile.txt'); 


о00000чпіітк()000000000000000оисһ()О0000чтітк)00 
0000000 


unlink('myfile.txt'); 


ПУМИХООООД0б000000000000000000000000000000000 


13.4 00000000000000ц 


ОДООДОО000000000000000000000000000000000РНР ООП 
ѓореп()О0000000000000000000000000000000000000000000 
ОО000000000000000000п700000м00000а0Ш 


ѓореп()О0000000000000000000000000000000000000000 


ОО000000000 
$fp = fopen("test.txt", "г" }; 
ООО000000000000000 


$Tp = fopen("test.txt", 'w"); 


ООООО0000000000000000000000000000000 


$fp = fopen("test.txt", "а"); 


ОДбО0900000000000РФрепо)ДдрО0баїзеродродродроддрбодрооо0о 
ОО00000000000000000001#100000000 
if ($fp = fopen("test.txt", "w")) í 


// do something with the $fp resource 


) 
ОООО000000000000000000000000000000000000 


($fp = Topen("test.txt", "м")) ог die("Couldn't open file, sorry"); 


П0ғореп()О0000чеПо00000000000000ае() 000000000000 
ОД00000000000000000ог00000000000000000а1е0000 


ОООО0000000000000000000000000000000000000000000 
ѓсіоѕе()000000000000000000ғореп()00000000000000 


fclose(S$fp); 


ОДООО000000057РО0О0000000000 


13.5 ППО 


РАРООООООООООО0О0О000О000000000000000000000000000 
00000000 


13.5.1 |деє5()ПРео Р" ПОО00000 


ОО0О0000000000000000000000000000000000000000000 
ПТоев ООО000000РорепОДОДО000000000000000000000 
ѓоеёѕ()О0000000000000000000000000000000000000ғеёѕ()0 
ОДООД00000000000000712700000000000000000000000000000 
ООО0000000000000 


$line = fgets($fp, 1024); // where $fp is the file resource returned by fopení) 


000000 ѓоеёѕ()0000000000000000000000000000ғеоғ)000 
ОДОООО0000000000000000000ксиердОДгатз ердтео 0000000 
ОО0000000000 


feof($Tp); // where $fp is the file resource returned by Тореп() 


ОООО000000000000000000000000013.8р00 


000013.8 ОДОДОДОДО00000 


: «?php 

: $filename = "test.txt"; 

: $fp = fopen($filename, "г" } ог die("Couldn't open $filename"); 
: while (!feof($fp)) { 

$line = fgets($fp, 1024); 

echo $line."«br/»"; 


) 


2> 


о 400i + G о = 


IILI readtTines. php web iin db D D Web 008 
О00000000013-з00000000000000000000000 





localhost/13/readlines.php 
= Q ©) http//localhost/13/readlines.php a, 


Hello world! 





013-3 readlines.php[][]] 


00003000 борепооб0000000000000000000000000000000 
or ате()О0000000000000000000000000000000000000000000 
ПП 


ООО00000000000400 while П00%һ!еро0000000000000 
ѓеоѓ()0000000 true ОДООДОООДОДООООООД000О00О0000000000000 
О000500079ев ОДОДО0000000 102400000000010 1924 П000000 
00005 ie ОООО60ООО000Д000000000000000000хс26г/2 000 


13.5.2 ||Тғгеаао 00000000000000 


ОДОДООО0000000000000000000000000000їгеаа 0000000 
ООО000000000000000їгеаа оООоб0О000000000000000000000 


$chunk = fread($fp, 16); 


0000 13.9 ПОООД000000080000000000000000000000 


П00000000геааіпеѕ2.рћроО0000%ебро00000000000000 
Учеб ПДОДО0000000001 34000000 


[=] localhost/13/readlines2.ph; 
€ С! О http;//localhost/13/readlines2.php 2, 
Hello wo 


another 
thing.. 


013-4 readlines2.php| ПП 


000013.9 [fread 00000 





: <?php 

: $filename = "test.txt"; 

: $fp = fopen($filename, "r") ог die("Couldn't open $filename"); 
: while (!feof($fp)) 4 

$chunk = fread($fp, 8); 

echo $chunk."«br/»"; 


} 


?> 


ON nab ary — 


О0#геаа()О0000000000000000000000000000000000000 
0000000 #ѕеек()С000000000 


ѓѕеек()ЈО0000000000000000000000000000000000000000 
ООО0О00000000000000000 


fseek($fp, 64); 


005013.1000#ѕеек()Оғгеаа()5650000000000000000 
00013.10 Пбёѕеек()00000 


: <?рһр 

: $filename = "test.txt"; 

: $fp = fopen($filename, "r") or die("Couldn't open $filename"); 
: $fsize = filesize($filename); 

: $halfway = (int)($fsize / 2); 

echo "Halfway point: ".$halfway." <br/>\n"; 

: Tseek($fp, Shalfway); 

: $chunk = fread($fp, ($fsize - $halfway)); 

: echo $chunk; 

2> 


SOON оо ол +> с N = 


— 


000000000геааз5еек. phpriE E web ОООООДОДОДОДОДУУебд) 
ОО000000000001 35000000 





[5] lacalhost/13/readseek.php 


= [2 (9 http://localhost/13/readseek. php а 





013-5 readseek.php ППД 


ОДООО05000061е5ігеОДО0002000000000000000700000000 
[fseek дорого о0о0000000000000000008000їгеаа 0000000 
ОО0000000000000000 


13.5.3 Пуєдеєс 00000000 


fgetcOLILIL] ғоеёѕ()00000000000000000000000000000000 
ООО0000000009ессорОДОООб00000000000000000000 


Фсһаг = fgetcí($fp); 


0000 13.11 000000000000 test.txt ООДОООООО0000000000 
ОО00000000 


000013.11 П0ғоеїс()00000 


: «?php 
: $filename = "test.txt"; 
$fp = fopen($filename, "r") ог die("Couldn't open $filename"); 
while (!feof($fp)) 4 
$char = fgetc($fp); 
echo $char."<br/>"; 


) 


2» 


ON OA + о о — 


000000000геааспаге. php] D We bpm p p p p TE 
Учеб ПДОДО0000000001 3-6 90000 





lacalhast/13/readchars.php 


С! ©) http://localhost/13/readchars.php а 


| 


-a ۹ ت‎ g 


> 


а. B 


ч п m + б в gm 


П13-6 readchars.php[]LL] 
13.5.4 [file get contents()ULL DLL 


ОД0000000Р0репоОродододрбообОббООООД0000000000000 
file get сопёепїіѕ()О0000000000000000000000000000000000 
П00еѕ. ЄхЕОДОДОДО00000005 сопеепіь00000 


$contents = file get contents("test.txt"); 


О00000000000000000000000#е дес сопёепїѕ() 00000000 


file get contents ($filename [$use include path |, $context |, $offset |, 
$maxlen 1111); 


00000000 


use include path ——00000000000000000000000О 
include path[] 

context ——[][|stream_ context _create()H0000000000000 
ОООООООМО у] 

offset - - ПД ОООДО000050000005000000000000000000 
(БІГПППІе get сопіепёѕ()000000000000о#ѕеё 

maxlen ----ОД0ОДОО000О00000000000000000000 


ОООО00000000000000000000000Й1 дес contents ОДОДОО 
ОО0000000000 


13.6 [| j III 


ОДОО0О0000000000000000000000000Р0реподродордрб000 
ОД000000000РорепООО0О00000000007м7 000000 


$fp = fopen("test.txt"'", "w"); 


ОООО0000000000000000000000000000000000000000000 
ООО000000000000000000 


ПО00000000000ғореп()000000000*а” 000000 


$Tp = fopen("test.txt", "а"); 


ОООО0000000000000000000000000000000000000000000 
000000 


13.6.1 (ПАигке Прико OLLLLU 


ћгіе()О0000000000000000000000000000ғ#риоєѕ()000000 
ШЕШИНЕ 


fwrite($fp, "hello world"); 
fputs($fp, "hello world"); 


О000000000000013.1200#мгҝе()0000000000000ғриѕ()00 
ООО000000000000 


000013.12  000000000000 


1: <?рһр 

2: $filename = "test.txt'; 

3: echo "<p>Writing to ".$filename." ... </p>"; 

4: $fp = fopen($filename, "w") ог die{"Couldn't open $filename"); 
5: fwrite($fp, "Hello world\n"); 

6: fclose($fp); 

7: echo "<p>Appending to ".$filename." ...</р>"; 

8: $fp = fopen($filename, "а") ог die{"Couldn't open $filename"); 
9: fputs($fp, "And another thing\n"); 

19: fclose($fp); 

11: 7» 


LODEWebrTI BD TD ETE III IL 


Writing to test.txt ... 
Appending to test.txt ... 


ПОбОсезе 00000 геаа те. рлроорооороооонооооообо 
ULL] 


Hello world 
And another thing 


13.6.2 (Пе put contents()[ILLLIL 


IL file get сопёепіѕ()000000#е put сопіепёѕ()0000 
ОДОД00000000000000000Й1е put. contents OOO0000000 
ѓореп()Оћмгіе()Пғсіоѕе()0000000000 


ПО00000# е put. сопёепёѕ()П0000000000 


file put contents ($filename, $data |, $flags |, Scontext]]}; 


ОО0000000000 
° data ----ОДО00 000000000000 


° flags ——[JQUUUFILE USE INCLUDE РАТНЦППП 
include раси ОДОДОДОДОРІ Є АРРЕМОрО00000000000000 
ООДОДО0000005-0Ск ЕХОДООООООООООООДОООО000000010 
0000000 

° context ——stream context сгеасе ОПИОООООООООООООО 
ПОВОМУЕЕЦ 


О000Н1е put contents ОД0000001 3. 1 20000000000 13. 13 
OOL 


000013.13 0000000000 


: «?php 

: $filename = "test.txt"; 

: echo "«p»Writing to ".$filename." ... </p>"; 

: file put contents ($filename, "Hello worldin"); 

: echo "<p>Appending to ".$filename." ...</р>"; 

: file put contents ($filename, "And another thing\n", FILE APPEND); 
2» 


NOOR о = 


13.6.3 ППћПоскоПпоо| 


ОО0О0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ООО00000000000000000000 


РНРО00#оск()0000000000Яоск()00000000000000000000 
ПОСООООСООООСООООСО0000000#оск()0000000000000000000 
ОДООДОО0000000000000000000РНРОДОООООООООДО0000000000 
000 3-100000000000000030000 


[13-1 | ЯосКк()0000000 


"pt ООО000000000000000000000000000 


НО 
= ОО00000000000 


0000000ореп()000000Яоск()0000000000000000000000 
О О О О JLTL TL] 


$fp = fopen("test.txt", "a") ог die('Couldn't open file."); 
flock($fp, LOCK EX); // create exclusive lock 

ff write to the file 

Flock($fp, LOCK UN); // release the lock 

fclose(S$fp); 





ПОД 


13.7 100 


ПИПШИШИШИШИШИШИПИШИИШШПШПИШППППИШПЇППРНРШШШШШШИШШШИШ 
ОО0О0000000000000000000000 


13.7.1 [j| jmkdir()[][|[][ ] 


ткаіг()0056000000000000ткаіг()С0000000000000000000 
ОООО0000000000000000000000000000000000000090000000 
ООД000800000000 7 7 7104001 | 


DEIEIBIEI EU МІХОДОДООДОООООООДО00/ 00О0ЗОД000000000000000 
LLILLILLI LIL LIL LI LIL LILLIL LIL LI LImkdir(O[ I E Erw eL 0 Fa Is e DET 
пкаіг()О0000000000000000000001р000000 


ОООДО0000000009МІХООООООДО0О000000000000000000 
ООООО0000000000000000000/755П00000000000000000000000 
0000000 


mkdir("testdir", 0777); // global read/write/execute permissions 
mkdir("testdir", 0755); ff world/group: read/execute; owner: read/write/execute 


13.7.2 [J]rmdir()ULUL ][ J[ J 


ПШШЦПШШЦПИШШЦПШИШЦШШИШЦШШИЦШЦПгГТПАа!Г()ПЦППШИШЦШШИШШШШШШППП 
О0етат()ОООооооОоооооо0000000000000000 


rmdir("testdir"); 


13.7.3 []]opendir(QLDL D DO TL 


ОДОД0О0000000000000000000 ПШШШШШПорепа!г()ПЦППШПП 
ППорепаіт()О0000000000000000000000орепатіг()000000000 
ОДОО0О000000000000000000000000000таї15ер 0000 


зап = opendirí("testdir"); 


ПППППППФАОРППИПИПИПИППІП 


13.7.4 Птеада ОПИПООООПО 


0000 тоеёѕ()000000000000000000000 геаааіг()00000000 
О0000000геаааіг()00000000000000000000000000000000000 
О0геаадаг()О0ғаіѕер000геааатг()О00000000000000000000000 
13.1400000000000 


000013.14 Пбгеаааіг()000000000 


: <?php 
: $dirname = "."; 
: $dh з opendir($dirname) or die("Couldn't open directory"); 


: while (!(($file = readdir($dh)) === false ) ) í 
if (is dir("$dirname/$file")) í 
echo " (D) Es 


O N Ooh соу N = 


} 
echo $file."«br/»"; 


— 
© с 


} 
: closedir($dh); 
Loa 


— — 
№ = 


ПОПОВО readdir. ph pDEID Web ИП n IILI D D Web 
О000000001 3- 7000 





ГЕ localhost/13/readdir.php 


= C | © hito://localhost/13/readdir.ohp а 


m 





113-7 readdir.php| ГП 


П000зО00орепаіг()000000000000000500000000%мһ!еП00 
П0000000000000геаааіг()П000%мһ!еро0000000000000000000 
$fileQuU 


О while ДОДО00000005аїгпате 100$1е ООДООООО000000 
ООООО00060000000000000000000000000 7000000000900000 
ПО9О0000000000 


0000 13.14 Дм'пітеррроодродрородоодоброб0ОРНРеООДОДОДОП 
ОО00000000000000 


while ($file = readdir($dh)) { 


echo $file."<br/>"; 


} 


О00000000геаааг()00000000000*0”000000000000оеп 
ОООО0000000000000000400000020205000000000000000000 
ПП 


О00000000000000ОмгеаааігорддоДОДООтатверророр000000 
0013.140000002 = 00000 геааа ко 00000000тазе ррооо00000 
Дорробтатьерроодро0000000 


ОПОПООПОООООООООООПОПОООООПООПООПООПООПООПООПОООООПОООООООЛОДО 
ОООД000000000000000000000000 x 


13.8 |Прореп ПОДОО0О0000000 


О00000000000000ғореп()00000000000000000000000000 
П00ррореп()00000000000000 


рореп()000000000 


$file pointer = рореп("зоте command", mode) 


ШЕШШ ДЕШЕ 


0000 13.15 ПОООДООООДО0О0000000000000000000000 


[00013.15 O0popen 0000000 





: <?php 

: $file handle = popen("/path/to/fakefile 2>&1", "r"); 
: $read = fread($file handle, 2996); 

: echo $read; 

: pclose($file handle); 

а 7» 


о лБ юм — 


0000002000рореп()009000000000000000030000000 
$file папатедПОДОД0000000040000000000005000000200000 
ППИПИПИПИПИПИПП Еее рореп.рпРродоДОС0С000000000УУебОО 
ООО000000000000000000 


The system cannot find the path specified. 


0000 13. ТӨП itipepen ODIEIBIDIBEITIDID EID EET EIE]U МИХ who 
000000 


000013.16 ППрореп()000МХ who[DBD rm NTXE] 


<?php 
$handle = popen("who", "r"); 
while (!feof($handle)) í 
$line = fgets($handle,1024); 
if (strlen($line) >= 1) ( 
echo $line."<br/>"; 


) 


= OA + O) осо ог = 


} 
pclose($handle) ; 
2 


002000000000000рореп()0000000000000003000000 
ммАероо0000000000000000000000060000000000000000000 
ОО00000090000 


ППИПИПИПИПрореп упо. риРООООООДОООДОДОДОДУУФеБООО 
ООООО0Д00000000000000000000000000000000000000 


julie pts/@ Mar 14 96:19 (adsl-63-206-120-158.dsl.snfo21.pacbell.net) 


000013.170000000000000рореп()08000000000000000000 
ОД00000000Осоїипопдро0О0000000000000000000000000000 
ПОбАЗСНОООО 


000013.17 Пррореп()0000000МХ соїипопДОДОДОДУМИХО) 





<?рһр 

$products = аггау( 
array("HAL 2000", 2, "red"), 
array("Tricorder", 3, "blue"), 
array("ORAC АІ", 1, "pink^"), 

array("Sonic Screwdriver", 1, "orange") 


); 


ON O (л bb O г — 


9: $handle = popen{"column -tc 3 -s / > /somepath/purchases.txt", "w"); 
19: foreach ($products as $p) 4 
ШЕ fputs($handle, join('/',$p)."in"); 
} 
13: pclose($handle} ; 


14: echo "done"; 
15: ?> 


002 000 000000000009 pred uets E ПОДОДОДООДО0О0004000000 
ОДОО0О000040000009000ОрорепбОО000000соїипапДОДО00000 
О00000Осо їм попДОоОбООООДОООб0ООД00000000000000003000 
ОДО000000000Пригсбавез Сх ОДОООООПООДО0ОО00000000000 
ПП 


ПП 10 000 12 100000 foreach 000%ргоаисіѕ [III ILILI LI IL 
ОО000000000000 Join ООООДООО0000000000000000000000000 
13 ПОООО0000000000 14 О00000000000000 


ООДО00000000 рореп_соіитп.рпроб0000000000000000 
Учеб ПООДООДООООДО0ОС0О00000000000000000000000000000000 


ПП 


HAL 2000 2 
Tricorder 3 
ORAC AI 1 
Sonic Screwdriver 1 


red 
blue 
pink 
orange 


ОДОД000000000 column ООО0000000000000000000000000 
ООО00000000000000000000 


13.9 [][]Sexec()[L 


ехес()0000000000 shell ППППИПИППИПППехесо ПП i II 
ООООО0000000000000000000000000000000000000000000000 
ОООД00000002П000000000 


exec("/path/to/somecommand", $output array, $return val); 


ПППП13.18ЦПЦехес()ЦППШПП sheW ci pibp b i Ip 


000013.18 Прехес()0001500000000000000мХП 


: <трћр 

: ехес("15 -al .", $output array, $return val); 
: echo "Returned ".$return val."«br/»«pre»"; 

: foreach (S$output array as $o) í 

echo $o."\n"; 


: echo "«/pre»"; 
?> 


со + O т. GO N — 


ПП 2 000000 ехес 000000 Is О0000000000000 
$output аггау00000000000000%геёигп_ маїддзобоодоророоо 
4000600 ТогеасһЦПЦПП%$оиїриї_аггауЦПЦПШППП 


OOL 
000000000Дехес 15.рАРобОДОООДОДОСОЗОДОУ/евоодбО 
0000009 3-8 ОООООО00000000000000000000000 


(С) tmp.htm! 


= 

Returned Ü 

total 100 

drwxr-xr-x 2 someusr 
атыхг-х--- 7 someusr 
—rw-r--r-- 1 someusr 
—rw-r--r-- 1 someusr 
—rw-r--r-- 1 someusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 someusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 someusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 someusr 
—rw-r--r-- 1 someusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 asomeusr 
—rw-r--r-- 1 someusr 


someusr 4096 
nobody 4096 
someusr 162 
someusr 763 
someusr 279 
Someusr 18 
Someusr 18 
Someusr 18 
someusr 155 
Someusr 23 
Someusr 95 
someusr 341 
someusr 165 
someusr 161 
someusr 220 
someusr 167 
someusr 166 
зошелізг 276 
зашешяг 123 
Someusr 30 
someusr 33 
someusr 39 
someusr 131 
someusr 95 
someusr 341 

[]13-8 


+ Jan 
‚ Jan 


Jan 
Jan 
Jan 
Jan 
Jan 
Jan 


| Jan 


Jan 
Jan 
Jan 
Jan 
Jan 
Jan 


г Jan 
5 Jan 
5 Jan 


Jan 
Jan 
Jan 
Jan 
Jan 
Jan 
Jan 


Q ©) nttp;//localhost/13/exec Is.php 





exec ls.php 
filetests.php 
getbinary.php 
incfilel.txt 
incfile2.txt 
incfile3.txt 
loopy include.php 
myinclude .php 
myinclude? .php 
popen column.php 
popen who.php 
readchars . php 
readdir.php 
readlines.php 
readlines2.php 
readseek.php 
returnvalue.php 
TESTE. EEL 

test include.php 
test include2.php 
test popen.php 
test returnvalue.php 
watile.php 


exec І5.рһрППП 


ПОРАРООООООООООООООООООООООООООООООРАРООООООООО 
ОДОД0ОРегібоООО0000О00000000000000000000000000000000 
ехес ПОДОДОРегіДоДПООООДООООО000О00000000000000000000 
ОО0О00000000000000000 


13.10 [j]system()[]passthru ()ЦПЦИПП 


ѕуѕёет()О00ехес()О0000000000000000000000000000000 
ОО0000000000 


system("/path/to/somecommand", $return val); 


зузтегп()0Дехес  ОДОДОДОООО00О000О00000000000000000 
О00ОО5у5сет00 man ОДО000 man 000000000<рге> </рге>[ 
000000 


<?php 

echo "<pre>" | 

system("man man | col -b", $return val); 
echo "</pre>"; 

?> 


ППЦПра5з5їһги()ПЦПППП5$у5їет()ПЦПШПШПШШПШШШПра55їһги() 
О00005пепбррорбробобродродоободоророрбододродрорббдоодоб 
ОД000000000005п епоррооророворор000000000002 3. 19000 


[00013.19 ППраѕѕћги()0000000 


: <?php 
: if ((isset($ GET['imagename'])) && (file exists($ GET['imagename']))) í 
header("Content-type: image/gif"); 
passthru("giftopnm ".$ GET['imagename']." | 
pnmscale -xscale .5 -yscale .5 | ppmtogif"); 
: ) else í 
echo "The image ".$ GET['imagename']." could not be found"; 


OO YOO + QON — 


. ?> 


00000000$ВеиПО0009 оритОрптпзса!е0ррт09и00000000000000000000 | 
00000000090000000 cp 000000000090000000009000000000900000000раз$ги(). 
000000 | 


IILI IILI L LIIgetbinary.php[ II ILILIILILIIIHTMLIII! 


«img src="getbinary.php?imagename=<?php echo urlencode('test.gif") ?>"> 


000001 3.19)0200000000000000000000НЙ7МЕ0000000 
test. 9ЇЇДОДОООДООДО0Д0О000000051Р»000000000030000 


ПО 4 000 5 Образ ги 0000000 З 00000009і#&оритр 
рптѕсаіе0рртіёоі О00000000000000000 гожбразз ги OL] 
ПОО0000000000000000000 


ПО00000000000000000000еѕсареѕће!іста()беѕсареѕћеаго() 00000000000 | 
ОО000000000000000000000000000000000000000000000000000000000000000 : 
00 x 


$new input = escapeshellcmd($ GET['someinput']); 


ООО0000000000000005пему при 000005. GET [ 'semeinput шын 
ОООД000000000000000000000000000000000000000000000000 u 


13.11 ||| 


ОДОО0000000000іпсічаед ООіпсїиде опсе()гедціге 000 
П0000геачге опсе()О00000000000000000000000РНРО00000 
ООООООРНРеОООООООООДОООООО0000000000000000000000000 
ООООО00000000000000000000000000000000000000000 


ОДООДОО000000000000000000000ОРАРООООООООД00000000 
ОДОДООО000000С0РепбоорО00000000000000ПрорепоП 


exec()[]system()[]passthru ПОДОДОДО0000000 


ОД000000ОрорепООООО0О0000О0000000000000000000000 
ОО000000000000000000000000000000000ехес()О05уѕёет()00 
О0005һе0000000000000000раѕѕһги()О000000005һе!р000 
0000000 


ООООО0000000000000000000000000000000000000000000 
ОООО000000000000000000000000000000000000000000000 


13.12 О&А 


ОПіасімаердоо000000 


АООООДОООООО00О00000000000000000000000000000000 
ОО00000000 


ОбООООООО0бО00000000000000000000000 

АВОООО0000000000000000000000000000000000ае()000 
ООООО0000000000000000000000000000000000000000000000 
000000 


ОбОООО0б00000000000000 


АППМевпипооооПоОО и тсот Stein п ООО Тре World 
Wide Web Security ҒАОППППП 
http://www.w3.org/Security/Faq/ 000 


13.13 (ULL 


ОООО000000000000000000000000000000000000000 


ӨШ 


ТОДО00000000000000000000 

2 П000000000000000000000000 
ЗОДОД0000000000 

АД ООО000000000000000000 

SLIDE 0000000000000000 

6 ОО000000000000 
ТОДОО00000000000000000 

eL abb E? 
ЗОДОООО0000000000000000000000000 


1оП0000000000000000000 


1100 0000000000000000000000000000 


120000000000005һеноо000000000000000000 


ЕШ 


1000000геаите  тсмае ПППРНРПИПИПИППИПИППИПГІ 


[include once()[]require once()[] 
20000000#е_ехіѕ5()00000000000000 
З0ћ!еѕіғе()О0000000000000 


А ғореп()00000000000000000000000000000000000000 
ПП 


5рѓоеёѕ()000000000000000000000000000000000000000 
ОО0О0000000000000000 


6р0000теої ОООО0000000000000теоРородрОвгиер 
70000000#рчєѕ()0000000000000 
8Порепаіг()О0000000000000000 
ӘПгеааатг()0000000000000000000000 


10Прореп()000000000000000 


11000000000000000000000000000000000000000000000 
ѓеоѓ()Пѓодеёѕ()000000#риїѕ()0000 


120000000000 shell[ 0000000000 escapeshellemd([] 
escapeshellarg (00000000000 


ЦЕН 


О О О О О О ОО 
ПП 


ӘП ППППИПППППППИПП 1 ВО00000000000000000000000000 
[<br/> ООДОДООООДО00О0000000000000 


014] OUOU 


ООО000000000000 


° ПОООРНРОДОДООДООООО 
° ПП 
° ПООО000000 


РАРОООООООООООООО000О000000000000000000000000000 
ОООДО000000000000000000000000000000000000000000РНР 
ОО00000000000 


14.1 ПИЛ 


ОПОР АРОООДОДООДО0ОО0О00Д00000000000005мчто Painti ICorel 
DRAW[Windows ОгамПОО0000000000000000000000000000 
ООООО0О0000000000000000000000б1Р»0)РЕСОРМОПО0ОО0О0 
000000 


ОДОООО000000000000000000000000РНРОООООДОО0000000 
ООООО000000ОРНРОДОООООООООООООО0О00000000000000000000 
ОООО0000000000000000000000000000000000000000000000 


ОО0О000000РНРО00000000000000000000000000000000000000000000000 
РАНРООДОООООООО00О00000000000000 


ООДО00000000000000000000 RGB оооооововобобобо«Оо 
O ВОДОД000000 0 0 255 ОООООДО0О0О00О0000000000000000000 
О00000000002550000000000 


ПОООООО0ВЄ8000255П00ПОПОДООО0ОДО00000000000000000 
П00000000255ПОПДОО000000П0П00255П000000000В0800 
02550 255 0255 ПОПИО ВОПДЛОПОПООООДОООООАЄВОГО1530 
5 115 З0000ОООКо ВО 2 94120 4 12 040 000000000000 
http://en.wikipedia. org/wiki/Web colors ПДООВеВОДООО 


14.2 РНР] 


РНРООООООООО Тпотаз BoutellriG РГ ПП LIL I 
ООООО000000000000000000000000000000 


ПОДООДО00СЄ0прДО0і і пих/ОМІХОДОДОДОДОРНРОДОООДОДОП 
00000 


--with-gd 
ООООРНРОДООДО00000040000000000Оплакебпаке install 


ОДОДООООС Р МА пасом 5 TEILT EIU php. 9аг.айдОрир и 000000 
Оо00р00004000000 


000 eb П0000000000000000000000000 GIF 000000 


ПП GIF ОО00000000000000000000000 Linux/UNIX QOL 
JPEG [] PNG ПООООООООООО000000000000 PHP 0000000 
ОМ паом/ ПППОПИВОНОИНОВОВОВВ 


е ТРЕОПОООООООПЕЄ://мммммм. )д.огд/ 000 

• PNGUUUUUUUUNttp ://www.libpng.org/pub/png/libpng.html! 
000 

• ООООДОРМОС-2ДДОД0О00021їЇ6ОООООР'ЕЄр://ммуммм. z hib. net/ 00 


О00000000000000000000000пих/ОмІіХО00000000000000 
РАНРОДОООООООО00000000ОРНРОООООООООСО0ЗОО00000000000000 
0000000 


--with-jpeg-dir=[path to jpeg directory] 
--with-png-dir-[path to PNG directory] 
--with-zlib=[path to zlib directory] 


ООООРАРОДООООДОООД0400000000000 make [] make 
install ПИТТ 


14.3 ПООООООО 


ОО000000000000РНРрО0001тадесгеаѓе()000000000000000 
ОДОООО00000000000000000000000000ОРНРеОООДО0 


ПООО00О тадесСтеаве ПОООО0О00000000000000000000000 
ООДОО00000003990000300000000000 


$myImage = Ттадесгеате (300,309); 


ОООО00000000000000000000000000000000 
ImageColorAllocate ОПОВ Є ВОД ОЗО0ООО00000000000000000 
00000 


$black = ImageColorAllocate($myImage, 0, 0, 0); 
$white = ImageColorAllocate($myImage, 255, 255, 255); 
$red = ImageColorAllocate($myImage, 255, 6, 0); 
Фагееп = ImageColorAllocate($myImage, 0, 255, 0); 
$blue = ImageColorAllocate($myImage, 0, 0, 255); 


ОбООО0000000000000000000000000000000000000000000000000 
$background соіогог 0000000000000 


ОООО0000000000000000000000000000000000000000000 
урммев 0000 


14.3.1 (ПТ 
ОООДОРНРОДООООООО0О00000000000 


ImageEllipse( 00000000 
ІттадеАгс()ПП000000000 
ІтадеРоіудоп()0000000000 
ImageRectangle()[ 000000000 
ImageLine()[ ПП d 


ООО0ОО0000000000000000000000000000000000000000000 
ОО0О0000хХО000У0О000000000000000000000000000х00У0000 


ULL] 


000000000000000000000000(15,15)000000000 8000000 
П0001400р0000000000000(95,155)00000000000000000000000 
0005 red I IL 


ImageRectangle($myImage, 15, 15, 95, 155, $red}; 


ОО000000000000000000000000000000000000000000000 
ULL] 


ImageRectangle(S$myImage, 95, 155, 175, 295, S$white); 


ООООО0000000000000000000000000000000000000000000 


ImageRectangle($myImage, 175, 15, 255, 155, %гей); 


00001.4.10000000000000000000000000000000000УУебі/ 0 
ПП 


000014.1 00000000 


1: <?php 

2: (усгеате the canvas 

3: $myImage = ImageCreate(300,300); 

4: 

5: //set up some colors for use оп the canvas 

6: $black = ImageColorAllocate($myImage, 0, 0, 0); 

7: $S$white = ImageColorAllocate($myImage, 255, 255, 255); 
8: $red = ImageColorAllocate($myImage, 255, 0, 0); 

9: %агееп = ImageColorAllocate($myImage, 0, 255, 0); 


10: $blue = ImageColorAllocate($myImage, 9, 0, 255); 

12: //draw some rectangles 

13: ImageRectangle($myImage, 15, 15, 95, 155, $red); 

14: ImageRectangle($myImage, 95, 155, 175, 295, S$white); 
15: ImageRectangle($myImage, 175, 15, 255, 155, $red); 
17: //output the image to the browser 

18: header ("Content-type: image/png"); 

19: ImagePng($myImage); 

21: //clean up after yourself 


22: ImageDestroy($myImage); 
23: 7» 


0180001 900000000000 web ПОДООДОДОООООДО0МІМЕЮОЛО 
0р000Опеадегдорр0000Оіпладебі Ді паде)ред00і падеРпд0П 
ООДОО000000000000000РМЕ0000022000000і падебезігоу OT] 
ПООитадеСгеа*е() 00000000000000 


О000000000Опаадесгеате. рпРрОоДООООПУУеБОДОДОДОДОДОДО 
ООО000000000141000000000000 


C imagecreate.php (300: 300) 


m С! ©) http;//localhost/14/imagecreate.php | [К] A 9 
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14.3.2 [ШШШ 


0000 14.1 ООООДОДО000000РНР О0000000000000000000 
ULL] 


е ImageFilledEllipse( LLL 

• ImageFilledArc 00000000000 

е lImageFilledPolygon O(UUUUUUUUUD 
e |тадеНеаКВесСапа!е ОПОПООПОООО 


ОООО00000000000000000000000000024.2000000000000 
ООО0000000000000000001 3000150000000 


000014.2 ОДОДОДОДОДОДОД 


ON O, O + O N = 
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— — — — — м ل ل‎ cl c 
(О O) ч фо ол + G) n >... 


<?рһр 
//create the canvas 
$myImage = ImageCreate(300, 300) ; 


/[set up some colors for use on the canvas 

$black = ImageColorAllocate($myImage, 0, 0, 0); 
$white = ImageColorAllocate($myImage, 255, 255, 255); 
$red = ImageColorAllocate($myImage, 255, 0, 0); 
$green = ImageColorAllocate($myImage, 0, 255, 0); 


: $blue = ImageColorAllocate($myImage, 0, 0, 255); 


//дгам some rectangles 

ImageFilledRectangle($myImage, 15, 15, 95, 155, $red); 
ImageFilledRectangle($myImage, 95, 155, 175, 295, $white); 
ImageFilledRectangle($myImage, 175, 15, 255, 155, $red); 


/[output the image to the browser 


: header ("Content-type: image/png"); 


ImagePng ($myImage) ; 


//clean up after yourself 
ImageDestroy($myImage); 


; i> 


ОДОДО000000іпадесгеавеніі.риродродроДОм/ев III III III 


О0р00000000000014-200000000000000 


© imagecreatefill.php (300х3 


< С © http://localhost/14/imagecreatefill.php КТ M ~ 
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14.4 ПП! 


ОООО0000000000000000000000000000000000000000000 


ОООО000000000000000000000000000000000000000020 14.3 [| 
ОО0000000000 + 000 10 П000000000000000000000000000000 
000000 


ON oar GQ N = 


000014.3 ПШПШ 


<?рһр 
//create the canvas 
$myImage = ImageCreate(300, 300) ; 


//set up some colors for use on the canvas 

$white = ImageColorAllocate($myImage, 255, 255, 255); 
$red = ImageColorAllocate($myImage, 255, 0, 0); 
$green = ImageColorAllocate($myImage, 0, 255, 0); 
$blue = ImageColorAllocate($myImage, 0, 0, 255); 


//дгам a pie 
ImageFilledArc($myImage, 100, 100, 200, 150, 0, 90, Згед, IMG АВС PIE); 
ImageFilledArc($myImage, 100, 100, 200, 150, 90, 180 , $green, 
IMG ARC PIE); 
ImageFilledArc($myImage, 100, 100, 200, 150, 180, 360 , $blue, 
IMG ARC PIE); 


//output the image to the browser 
header ("Content-type: image/png"); 
ImagePng($myImage) ; 


//clean up after yourself 
ImageDestroy ($myImage) ; 
?> 
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001 20001 40000000 таден еаАгс ОПООООО000000 


0000000 

° ПОДОДОД00ХхОО 
ООО0О0000У000 
° ПП 

° ПП 
00000000 
00000000 

e ПО 
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000024.300124000000000 


О000000000000%0!че 000000000 ІМС АВС PIE 100 
ІМС АВС РІЕПООООООООООООООООООООООООООООООО 


ППИПИПИПИП птадесгеаѓеріе.рћро0000000 Web 0000000 
ОООО0000000000000014-З3О00000000000000 


e imagecreatepie.php (300: - 
= Q ©) http://localhost/14/imagecreatepie.php Коњ ~ 
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О000000001.4. ЗД00000000З3900000000000000000090300 
ООООО00000000000000000000000000000000030000000 


$lt red = ImageColorAllocate($myImage, 255, 150, 150); 
$11 green = ImageColorAllocate($myImage, 150, 255, 150); 
$lt blue = ImageColorAllocate($myImage, 150, 150, 255); 


ОДОД0000000000707000001000110000100010100000000 
ОО0000000000000000 


for ($1 = 11@;$1 > 100;$1--} í 
InageFilledArc (SmyImage, 190, $i, 200, 150, 0, 90, $11 red, IMG АВС PIE); 
ImageFilledArc ($myImage, 100, $i, 200, 150, 90, 180, $11 green, 
IMG ARC PIE); 
ImageFilledArc ($myImage, 100, $i, 200, 150, 180, 360, $11 blue, 
IMG ARC PIE); 


ПИА .40000000392000000 


Oooh wah — 


000014.4 1003000 


«?php 
//create the canvas 
$myImage - ImageCreate(300,3900); 


//set up some colors for use on the canvas 
$white = ImageColorAllocate($myImage, 255, 255, 255); 


7: $red = ImageColorAllocate($myImage, 255, 0, 0); 


8: 
9: 
19 
11 


I2: 


$green = ImageColorAllocate($myImage, 0, 255, 0); 

$blue = ImageColorAllocate($myImage, 0, 0, 255); 
: $11 red = ImageColorAllocate($myImage, 255, 150, 150); 
: $1t green - ImageColorAllocate($myImage, 150, 255, 150); 
$1t blue = ImageColorAllocate($myImage, 150, 150, 255); 


Ta 


14: 
15: 
16: 
17: 
18: 
19: 


//draw the shaded area 

for ($i = 110;$1 > 100;$i--) í 
ImageFilledArc ($myImage,100,$1,200,150,0,90,$91t red,IMG АВС PIE); 
ImageFilledArc ($myImage,100,$1,200,150,90,180,$91t green,IMG ARC PIE); 
ImageFilledArc ($myImage,100,$1,200,150,180,360,$1t blue,IMG ARC PIE); 

} 


20: 


21: 
22: 
23: 
24: 


//draw а pie 

ImageFilledArc($myImage, 100, 100, 200, 150, 0, 90, $red, IMG ARC PIE); 
ImageFilledArc($myImage, 100, 100, 200, 150, 90, 180 , $green, IMG АВС PIE); 
ImageFilledArc($myImage, 100, 100, 200, 150, 180, 360 , $blue, IMG АВС PIE); 


29: 


26: 
27: 
28: 


//|output the image to the browser 
header ("Content-type: image/png"); 
ImagePng($myImage); 


29: 


30: 
31: 
32: 


/{с1еап up after yourself 


ImageDestroy($myImage); 
?» 


ПО00000000 imagecreate3dpie.phprI nm Web DI 
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e imagecreate3dpie.php (300 


< С! ©) http;//localhost/14/imagecreate3dpie.php | S] КО А 
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ОООО0000000000000000000000000000000000000000000 


ПОООО падеСгеаєе()ПОДО0О000000000000000000000000000 
ІтадесСгеаіеЕготж*()0000 


ПОДООДО061Р0)РЕСОПРМОБООДОДОО0ОО00Д000000000000000 
ПІППППтадесгеагеҒотсіОПІтадесгеагеҒгот/рдор 


ІтадеСгеаѓеғготРпо()О000000000000000000000000000000 
О0000000014-500000000 


000074 500000000000000000000000000000 


e baseimage.png (350x 200) 


< С! | ©) http://localhost/14/baseimage.png kl A А 


This is my base image. 
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1: <?php 

2: //use existing image as a canvas 

3: $myImage = ImageCreateFromPng("baseimage.png"); 

4: 

5: /fallocate the color white 

6: S$white = ImageColorAllocate($myImage, 255, 255, 255); 
т 

8: //draw on the new canvas 

9: ImageFilledEllipse(SmyImage, 100, 70, 20, 20, $white) 


y 
19: ImageFilledEllipse($myImage, 175, 79, 20, 20, $white); 
11: ImageFilledEllipse($myImage, 250, 79, 20, 20, $white); 
12: 

13: //output the image to the browser 

14: header ("Content-type: image/png"); 

15: ImagePng($myImage); 

16: 

17: //clean up after yourself 

18: ImageDestroy($myImage); 

19; 7> 


П000000000тадеїотраѕе.рћр0000000%еоп00000000 
О00000000000000014-6000000 


e imagefrombase.php (350: 


= С! QO http://localhost/14/imagefrombase.php | [Hl A А 


This is my base image. 
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ОООО0000000000000000000000000000000000000000000 
ООО40РМОПОДООООООООООО00О0О000000000000000000 14.6 ПП 
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ООЗОД0Д000000000000000000000іпт91.рп9008000 1100 
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ОЗОДО000000000000 


000014.6 — ОДООО00000000 


<?php 
/f/select an image to start with 
$baseimage = ImageCreateFromPng("imgi.png"); 


/floop through images #2 through the end 
for($i-2; $i «5; $1++) 1 
//allocate the transparent color, and stack 
$myImage = ImageCreateFromPng("img".$i.".png"); 
9: $gray = ImageColorAllocate($myImage, 185, 185, 185); 
10: ImageColorTransparent($myImage, $gray); 
11: ImageCopyMerge($baseimage,$myImage,0,0,0,0,150,150,100); 
12: | 


о 00.» о = 


14: //output the image to the browser 
15: header ("Content-type: image/png"); 
16: ImagePng($baseimage); 


8: //clean up after yourself 
19: ImageDestroy($baseimage); 
20: 7» 


ООЗО0000000000000000000000000000000000000000000 
О00000000000000000000040000000002500016П000000000 


ОДОДО000000імадезіаскег php] idt Web 00000000000 
ОО00000000000014- 7000000 





e imagestacker.php (150х151 
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ООО0О0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000 


0000014. 7О0000000000000000000000000000000000000 
ОО0000000000000000000000000000ітадеѕїгіљо()0000000000 
UO" OU" WOU 


ПИШШШШШШШШП 2 000 38 ООООООО0000000000000000000000 
ULL] 


000014.7 ДПОДО00000000 


O YOO + dN = 


Оо 


«?php 
if (!$ POST) ( 
/[show form 
2> 
<!DOCTYPE html» 
«html» 
<head> 
«title»Image Creation Form</title> 


«style type="text/css"> 

fieldsetí(border: 0; padding: 9px Орх 12px Орх;) 
fieldset label (margin-left: 24рх;) 

legend, label (font-weight:bold;) 

</style> 


</head> 
<body> 
<hi>Create an Image</h1> 


<form method="POST" action="<?php echo $ SERVER['PHP SELF']; ?>"> 


<fieldset> 
«legend»Image Size:</legend><br/> 
<label for="w">W:</label> 
<input type="text" id-"'w" 
<label for="h">H:</label> 
<input type="text" id="h" 


name="w" size="5" maxlength="5" /> 


name="h" size="5" maxlength="5" /> 


</fieldset> 

<fieldset> 

<legend>Background Color:</legend><br/> 

«label for="b_ r">R:</label> 

<input type="text" id="b г" name="b г" size="3" maxlength="3" 
<label for="b_g">G:</label> 

<input type="text" id-"b g" name="b g" size="3" maxlength-"3" 
«label for="b_ b">B:</label> 

<input type="text" id-"b Б" name-"b b" size="3" maxlength-"3" 
</fieldset> 

<fieldset> 

<legend>Text Color:</legend><br/> 

«label for="t_r">R:</label> 

<input type="text" id-"t r" name-"t r" size="3" maxlength-"3" 
«label for="t_g">G:</label> 

<input type="text" id-"t g" name-"t 9" size="3" maxlength-"3" 
«label for="t_b">B:</label> 

<input type="text" id-"t b" name-"t b" size="3" maxlength="3" 
</fieldset> 


<p><label for="string">Text String:</label> 


<input type="text" id="string" name="string" $12е="35" 


<p><label for-"font size">Font Size:</label> 


«select id-"font size" name="font_size"> 
«option value="1">1</option> 
«option value="2">2</option> 
«option value="3">3</option> 


«option value="4">4</option> 


/></р> 


{> 


{> 


{> 


{> 


{> 


/> 


58: «option value-"5"»5«/option» 

59: </select></p> 

61: <fieldset> 

62: «legend»Text Starting Position:</legend><br/> 

63: «label for="x">X:</label> 

64: «input type="text" id="x" name="x" 517е= 3" maxlength="3" /> 
65: «label Ғог-"у">Ү:</1аһе1> 

66: «input type="text" id="y" name="y" size-' 3" maxlength- 3" /» 
67: </fieldset> 

69: «button type="submit" name-"submit" value-"create'»Create Image</button> 
70: </form> 

71: </body> 

72: </html> 
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000000 imageloadfont()[] imagettftext()LILIEILILILILILIL] http ://ww w. php. 
net/image [] 
0000640006600000000000000000000Х00000У000000000 
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C 
e Image Creation Form 
€ > С (0 http://localhost/14/imagestring.php Комо ~ 


Create an Image 
Image Size: 

W: H: 
Background Color: 

R: G: В: 
Text Color: 


R: G: B: 


Text String: 


Font Size: 1/- 


Text Starting Position: 
X: Y: 


| Стваїе |таде | 
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0000 23 О0000000000000000000000000000000000000 
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73: «?php 

74: ү else ( 

79! /[create image 

76: //create the canvas 

77: $myImage = ImageCreate($ POST['w'], $ POST[ h']); 
fo: 

79: /{/set up some colors 

89: $background = ImageColorAllocate ($myImage, $ POST['b r'], 
81: $ POST['b g'], З POST['b 571); 

82: $text = ImageColorAllocate ($myImage, $ POST['t r'], 
83: $ POST['t g'], $ POST[ + b']); 

84: 

85: // write the string at the top left 

86: ImageString($myImage, $ POST['font 5122 |, $ РОЗТ['Х |, 
87: $ POST['y'], $ POST['string'], $text); 

88: 

89: /foutput the image to the browser 

90: header ("Content-type: image/png"); 

91: ImagePNG($myImage); 

92: 

93: //clean up after yourself 

94: ImageDestroy($myImage); 

95: | 

96: 7» 
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C imagestring.php (200: 50) 
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«img src-"NameOfScript.php" /> 
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<?рһр 
//create the canvas 
$myImage = ImageCreate(150,25); 


//set up some colors for use on the canvas 
$white - ImageColorAllocate($myImage, 255, 255, 255); 
$black = ImageColorAllocate($myImage, 09, 0, 0); 


со чч O, о + со n = 


о 


//load a font 
: $font = imageloadfont("hootie.gdf"); 


: // write the string 
: ImageString($myImage, $font, 0, 0, "САРТСНА!", $black) ; 


: //output the image to the browser 
: header ("Content-type: image/png"); 
: ImagePng($myImage); 


: //clean up after yourself 
: ImageDestroy($myImage); 
: 7> 
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1: <!DOCTYPE html» 

2: <html> 

3: <head> 

4: <title>Using Images Created by Scripts</title> 

5: </head> 

6: </body> 

7: <hi>Generated Image Below...</h1> 

8: «img src-"imagecustomfont.php" alt="generated image" /> 
9: </body> 

10: </html> 


рроронтміДдродрододбододдреророео00000000їп139000 src [| 
00000000 14.800000000000 imagecustomfont.phpQQUUHTML 
ПППППивеітаде. Пе ППОНТМЕПРНРОПППООМе ПОП 


ПО00000азентаде лет 00000000 + 4- 1 О0000000000000 О 
ОП" САРТСНА""ООООО00000000000 





e Using Images Created by 5 


€ С ©) http;//localhost/14/useimage.html кі м А 
Generated Image Below... 


CAPTCHA! 


[14-10 ООООООООО 


ООООО0О0000000САРТСНАПООООООООО0ООО0О000000000000 
ООООО000000000000000000000000000000000000000000 


14.8 || 


ООО0000000000 РНР О000000000000000000000 
http://www.php.net/image ПРНРППО аде Functions” 000 


ООООО0000000000000000000000000000000000000000000 


ООООО000000000000000000000 PNG ППППИППИППИППИППОІР 
ЦПРООДОООООДООО0000000000000000000000000000000000000 
ООО000000000000000000000000000000000000000000000000 
ОДООДО00000000000000 HTML ДОДО00О00000000000000 HTML 
ОО000000000000 


14.9 Q&A 


ОбОООООО0000000000000 


АООООДОООООО0ОО000000000000000000000000000000000 
ОООО000000000000000000000000000900000 


ImageFilledArc(S$myImage,59,50,100,50,0,90,$red, IMG ARC PIE); 


ООДОД000000000000000000000Мау Sales E ПООООДОДОДОП 
ПФ”пау sales ресе inimi b IILI I[ 


ImageFilledArc(SmyImage,50,50,109,50,0,$may sales pct,$red,IMG ARC PIE); 


ОООО0000000000000000000000000000000000000000360 
ПП 


14.10 ППП 


ОООО000000000000000000000000000000000000000 


ЦЕН 


І ПОООД0000000А09800000 
2 ОО00000000000399000002000000000 


ЗОООООО0000000000000000000 


ИЦ 


1І00000П0000000025502551255000000 


2 П00000000000000000000039000002000010 


$new image = ImageCreate(300,200); 


3[]lmagePolygon()[]llmageFilledPolygon()[] 


ӨШ 


100000000000000000000000000000000000 З900000000 
ОООО00000000000000000000000 19 0000000 


2000000 2 00000000000000000000000000000000000000 
ПППП 


1150 
1160 
02.70 


1180 


ЦАП] РНРЦМУЗОЦ | 


00000000 
SQL 
ПИМУ 5 О ППИПППШШШП 


ПОРНРЦМУЗОЦ Г 


0450 000000000 


ОО000000000 


ОО000000000000 

° СООО 

° ПШПШ 

° ПОООООО0000000000 


ООООО0000000000000000000000000000000000000000000 
ОМу5ОСОООООМУ5ОЗОООДОО00000000000 


15.1 ПООООООО0О00 


ООООО000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО00000000000000000000000000000000000000000000 


ООО0О0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 


ООООО0000000000000000000000000000000000000000000000 
00000 


ООООО00000000000000000000000000З500000000000000 
П00000Аамапсеа МаїћО00000000000000000350000000000 
О000000000Маһетаёсѕ ІМ000000035 О00000000000000000 
ОДООДО0000000000000190000000000000000000000000000000 
000000 35 0000 


ООООО0000000000000000000000000000000000000000000 
ОООО00000000000000000000000000000000000000000000000 
ОО00000000 


ООО00000000000000000000000000000000000000000000 
ООООО00000000000000000000000000000 


15.2 ШШШ 


ОО0000000000 


° TULL 
° СОШО 
° СОШО 


ППППППППППетріоуеев ППОДОДООООООО0О000000000000 
О00000000000аерагётепёѕ000000000000000000000000100 


ППИПППетріоуеевііІП ІП I IIIidepartments[I[IIIIDI LI IILI I III! 
001. 5-100000000000000000РКО«ДОО0000 


employees 


o SS Number 
DeptlD 
FirstName 


departments LastName 


(©) беріп 


ОеріМате 





015-1 employees[][]departments|j](]|L]Deptl D(]LILILIL] 
ОООООО000Д0000000000000 


15.2.1 (ПЦ 


ОД000000000000000000000000етиріоуеез5 ПП 
дерагітепѕ$П000000000000000000000000000000000000000 
ОООО000000000000000010002 5-20000000000000000000 





ECT 


015-2  ПОДОДО00000 


П0000етріоуееѕВПсотриѓег$=01000015-3000000000000 
ULL] 


employees 


m9 SS Number 
DeptlD 
FirstName 
| astName 
ComputerID 


computers 


(29 ComputerlD 
ComputerDesc 











[15-3  ПОДОДО00000 


15.2.2 [| UI) 


ОДООДО0000000000000000000000000015-1000000000000 
ОООД00000000000000000000000000000000000015-4000 


ОЕРАВТМЕМТ 
А 


EMPLOYEE 1 EMPLOYEE 2 EMPLOYEE 3 EMPLOYEE 4 


015-4 [HII 


ОООО0000000000000000000000000000000000000000000 
ПППППИПИПИППСАППСа!ШТогиаПрРАППРеппвуіматаПй IILI III IL 
ОО000000000 


ПО0008000СаНоглиа ПП ППОРеппзу мата ПОО0000000 
ООООО0О00000000САСОДОООООООООО000О0ПРАООДОДООООООП 


15.2.3 (ІІІ! 


ОООО0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000 


ООООО000000000000000000000000000001900000000000 
ООТФОД00000001 5-5000000000000000000000000000000000 


| STUDENTI | aL 
ws 
| STUDENT2 | | STUDENTG | 
x^ 
| STUDENTS | 
STUDENT 7 
STUDENT 4 CLASS 
C 
015-5  ДОДОД00000000 


ОООО0000000000000000000000000000000000025-60000 
0000000 


students classes 


(©) StudentiD © ClassiD 


FirstName ClassDesc 
LastName 





[15-6  ПОДО000000 


ООО0О0000000000000000000000000000000000000000000 
ОО00000000015- 7100000000000 


students classes map 


StudentlD 


ClassID 
students 


classes 


© studentID 
FirstName = ClassID 
LastName ClassDesc 





П15-7 students classes тарПТІППІПП 


000001 5-5000000000000000000000000015-8000000 





015-8 ППІППвшаелпіс classes тарП 
[0000000000000005чаеп*$5_сТа$5е5_тар 00000000 


ООО0О0000000000000000000000000 


15.3 ППП 


ООООО0000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000000 


ООО0О0000000000000000000000000000000000000000000 
ОДООЗОДОДОД000000000000000 


ООО0О0000000000000000000000000000000000000000000 
ОООО00000000000000000000000000000000000000000 


15.3.1 ML 


ООООО00000000000000000000000000000000000000000 
[flat сабтеПДОДОО000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000000000000 


ООО0000000000000000000000 


об идеп Мате — 10000 

CourselD1 ----ОООООООООООТОГ 
CourseDescription1 —-—([|]J ID tll 
Courselnstructor1 ——[|[ J lE b E b i iit] 
CourselD2 —— | rb 
CourseDescription2 —— [0000000000000 
Courselnstructor2 ——/[000000000000 
ПООвоОооооовоооОООСочгве ОП ]Cou rseDessceri ption[] 
Соигѕеіпѕёгисёог000000000 


ПОООООООООООООООООООООООО0О0О0ОСоигѕеІрП 
CourseDescription||Courselnstructor Па 


ООО0О000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000 


15.3.2 ПІ 


00000000 


° ПП! 
• ПОДООО00000000 


ООО0ОО0000000000000000000000000000000000000000000 
ОО0ОО000000000000000000000000000000000000000000000 
15-9000 





students 





@ StudentiD 
StudentName 
student_courses 
studentlD 
CourselD 
CourseDescription 


Courselnstructor 


[15-9 ООООООООО 


ПООДООДООДОО00000000000000000000000000000000000 
П.ПСочгѕеІр/Соигѕереѕсгіріїоп/Соигѕеіпѕёгисіог ПОП 


ОО000000000000 


15.3.3 (ІП! 
ОО00000000 


• ПООООООО0000000000 


ООО0О0000000000000000000000000000000000000000000 
ОО000000000000000000000000000005ёоадепёѕ_соигѕеѕ[ 


CourselD[]CourseDescription[]Courselnstructor[]L]EDLILILILIL] 
courses|[|[ |] ICourseIDI Ir IILI $ иает*$ соигѕеѕ$000000 
[JStudentID[]CourseID|[ [| IU 15-10[] LIU] 


students 


QD StudentID E courses 
StudentName a © Сіаззір 


student courses ClassDescription 


StudentlD Courselnstructor 
ClassID 





015-10 00000000 


ООООО0000000000000000000000000000000000000000000 
ООО000000000000000000000000000 


15.3.4 0000 
О00000000000 
• [| II III] 


ООО0О0000000000000000000000000000000000000000000 
ООООО00000000000000000000000000000000000000000000 
Социг<е1п5їгистог ОПОООООООО0ОО0О000000000000000000000000 
О0000000000000015-11000000000000 







courses 








щу ClassiD 
ClassDescription 
Courselnstructor|D - 





students 







© studentID instructors 


StudentName 







- a9 InstructorlD 
InstructorName 
InstructorNotes 






student courses 






StudentlD 
CourselD 






015-11 010000000 


OUD 
ОООО000000000000000000000000000 


15.4 [ILI 


ООООО0000000000000000000000000000000000000000000 
ОООО00000000000000000000000000000000000 


ОО00000000000 


° ПШ 

° ПООООО0000000 
° ПП 

° ПООО000000 

° (ПП! 


ОООО0000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000000000000000 


ОООО0000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000 


ОООО0000000000000000000000000000000000000000000 
ОО0О0000000000000000000000000000000000000000000000 
ООО000000000000000000000000000000000000000000000000 
ОО00000000 


ОО0О0000000000000000000000000000000000000000000 
ООО0О000000000000000000000000000000000000000000000 
ООО0О000000000000000000000000000000000000000000 


ОО0ОО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОДОО000000"000000000:Е6ппайородооодророоороводоро" 000 
ЕтанАаагеѕѕ$0О000000000000000000000000000000 


ОООО00000000000000000000000000000000000000000000 
ОООО000000000000000000000000000000000 


15.5 || 


ООО0О0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООО00000000000000 


ООО00000000000000000000000000000000000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
ПП 


ОООДО000000000000000000000000000000007 00007000 
ООО0О00000000000000000000 


15.6 О&А 


QUEUE 


АПОО00000000000000 Boyce-Codd EDJIEIBBIBIBBIBIBIBIEILII UTE 
Join-Projection[ HIDE BOE TEEBB 0000 00000000000000000000000 
ПОООбО00000000000000000000000000000000000000 
http://en.wikipedia.org/wiki/Database normalization#Normal 
forms [] 


15.7 (ІШІ! 


ОООО000000000000000000000000000000000000000 


ӨШ 


1000300000000 


2 В00000000000000000000000000000000 


ЗЦПШШПИШШИШШИШШШП 


ИЦ 


ТО0ДОООО00000000000000 
2 ОООД0000000000000000 


ЗОДОООО0000000000000000000000000000000000000000 
ОООО0000000059800000000000000 


ӨШ 


ОООО000000000000030000 


016] SQL 


ОО000000000 


ОООМу5ОЄ0О000 

ПОООСКЕАТЕ TABLE; [10000 

ПОООМЉБЕКТОООООООО 

ПОООБЕКЕСТООООООО 
ПООБЕКЕСТОПООООПОПОМНЕКЕ ПППОКООР ВУППП 
ОДОД/ОВМОДОДОДОДООГ 

ПООООРРАТЕПКЕРЕАСЕ ЦППИПООПОПО 

ПООООЕКЕ ТЕППОООООЦ 

ПОрОмузо 00000010 

ООДОМУуЗОФЕДООООЗООО0О 


ОДООД000000000000000000000050200000000000000000 
ОДОДОО00Му 50 ЄПОООДО0000000000000000000МУу5ОС0000000 
ПОМУЅОЩШЩОООО00000рпрмуАатіто000000000001000чіск 
Start ПП ОХАМРРОДОДОДоПрМуАдАатіп 


ООООО0000000000000000000000000000000000000000000 
00000 


16.1 MySQL 


ОООО0000000000000000000000000000000000000000000 
ОООО000000000000000000001300000000000009000800000000 
ОДООДОО00000000000000000000000000000007 00000070 


МУу5О СОООО0000000000000000000З00000000000000000 
ООО0000000000000000000000000000000000000000 


16.1.1 ПОП 


МУЗОРПОООДОДАМУІ У об 00000000000000000000000 О 
МУу5О СООООО0ОО0000000000000000000000000000000 





J00000000000000000000000000000000000000000000000000000000000000 
ООО0000000000000000000 


° INT ——О0000000000000000000000000000000000000 
—21474830648[]214 748364 7 ПППООООООООООООЦ 
429496 /295П0П1)0000001100000 

TINYINT ----ОООбОД0ОДО00000000000000000000000000 
- 128012 "ППО00000000000000255000000000 200000 
SMALLINT ----ОПООООООО00000000000000000000000000 
П-32 768132 76 "ДПДО000000000000П06553500000001050 
0000 

MEDIUMINT ----ООООООО000000000000000000000000 
000000- 8388608П838860 /ППООООООО000000000 


16777215П000000000900000 

BIGINT ----ООООООООО0О00000000000000000000000000 
—9223372036854775808[]922337203685477580 7 [TEL] 
ОДО000000000018446744073709551615ПДП00000022 00 
ULL] 

FLOAT(M,D) ——1000000000000000000000000 МОООО0О 
ОО90000000000000010,г2)00020000000300000000000000 
ОРЕОАТОДООДОДО004400 

DOUBLE(M,D) ——О000000000000000000000000000Мр 
ОООО00080000000000Ч900016,4000400000000РО09ВІЕПО 
ООООО0005З00КЕАЄСОРОУВСЕООДОП 

DECIMAL(M,D) ----ОПОПОООООООО0О000000000000000000 
ООООО0О000000000000МОДОООООДОООО000МОМЕВІСО 
DECIMALT[] TIL 


ПОООМуз о СООДОО000000001/М ТОООООООО00000000000000 
ОДООДО000000000001900000000070МУМО0ОГ9000000000000 
О00000000000000256П0000 


16.1.2 ШШШ 


МУу5О СООДОООО0О00000000000000000000000000000000 
ООО0000000090000000020300002000285029П0000З9о000000000 
ОО00000000000000000000000000198001100000010001980- 
11-О0ОБПООДООДОООО0О0О0000000000 


МУу5О СООООООО00000000000000000000000000000000 
МУ5О СООООООО0000000000001 2000000000031000Му50:000 
ОО00200ЗО00000000000000000000000000000000000РНРОООД 
ОООО000000000000000000000000000 


МуЗО СОООО0000000000 


DATE - - -УУУУ-ММ-000000000001000-01-01П9999-12- 
31000000197 30120309000001973-12-300 

DATETIME ——YYYY-MM-DD НН:ММ'5500000000000000 
1000-01-01 00:00:0009999-12-31 23:59:591000001973 
0120300003:3000001973-12-30 15:30:000 

TIMESTAMP —— 19 7001010000203 7П000000000000000 
ПОД ТИМЕЗ5ТАМРОДОООООООООООДОООДОДОДТІМЕ5ТАМРОДОО 
ПД14000000УУУУММООННММЗ 5 ОДОДО0000ОАТЕТІМЕДОО 
000000000000000019 /30120300003:3000000 
19731230153000ПТІМЕ5ТАМРПППИППП12 
(YYMMDDHHMMSS)[8 (YYYYMMDD)[]6 (УУММОО)П 

TIME ---ПНН:ММ'550000000 

YEAR(M) ——0200400000000000000002000ҮЕАК(2)00 
ҮЕАВППП1970П2069П170П169ППППППППП4ПҮЕААВППП1901[ 
215500000040 


ОАТЕТІМЕПРАТЕПОООООООООО0000000000 
16.1.3 [JII 


ОООО00000000000000000000000000000000000Муѕ5оП 


00000000 


CHAR(M) —0000000000001025500000000СНАА(5)000 
ОООО00000000000000000000000000000010 
VARCHAR(M) ----О000000000001025500000000 
МАКСНАЋК(25)000000УАКСНАВКОО000000000000 

BLOB [ТЕХТ —— 00655 35000000000ОВ ОВО “Binary 
Large Objects” ПОДОДООООООДОДООО00000000000000000000 
ПОООООО ТЕХ ТОДООООООООбОООООО0000000000000000000 
ПВЕОВОПИНИНОВООНТЕХ ТОДОООООООПОООООДОВСОВОТЕХТО 
0000 

ТІМҮВІ ОВ [|TINYTEXT ——00000255000000ВіОВр 
ТЕХТОДОООТІМУВЦІОВИТІМУТЕХТОДОДООО 

MEDIUMBLOB ПМЕРІЮМТЕХТ —— 00016 7 77 21500 
ПООВШОВЦТЕХТООООМЕРЈМВШОВЦМЕРОМТЕХТЦОООО 
ПП 

LONGBLOB [ILONGTEXT —— 11000429496 72950 10100 
ВЦШОВЦТЕХТООООЦСОМОВГОВОЈСОМОТЕХТООВООООО 

ENUM ——00000000000000000000000ЕМОМОООООООООц 
ОООО00000000000000000МУ ЕЕООВОВОВОВООНОЕ 
О"А"07В"0"С"ПОДОООДЕМОМОЕМОМ СА", ‘B’, 'СЗД00000000 
ОМОСЕДООООООООД0ЕМУМОСО655 ЗДОООООЕМОУМОДОДОООО 
0000 





5ЕТООДЕМОМОДОООООО000000000005Е ТООООО000000000006МО МООО00000 
0000000 x 


VARCHARI[JIEXT[I IILI IL IL IL ILULILILILIENUMII II IL 


16.2 [I I 


ООО000000000000 


° СОШ 
° TULL 
° ШШШ 


ОЗ000000000 


CREATE TABLE table name (column name column type); 


ОО000000000000000000000000000000000000000000000 
ООД000000500000000009госегу іпмепісогуДДОД0О000000000 
ООООО0000000000000000000000000000000000000000000000 
Об00000ісего патеђ000п0 


ППИПИПИПИПИППогосегу іпмепіогу ДОДОДОДО0100000000 
ОООДО00000000000000000000001900000000000000000000 
> О0000000000000065535П00000000000000000000000 


CREATE TABLE grocery inventory | 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
item name VARCHAR (50) NOT NULL, 
item desc TEXT, 
item price FLOAT NOT NULL, 
сип” qty INT NOT NULL 


iA ОООООООБОПООООООО000000000000000000000000000000000000000000 - 
auto іпсгеттепі ПОДООПОООПОМУЗОФЦООООООООООООООП001000000 x 


MySQLiUUUUQuery ОКПОПОООООООО0ОО00000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО0О000000000000000000000000000000 


16.3 ППІМ5ЕВТІІІ 


ОООО00000000050:00ІМ5ЕВ ТОООООООО0О000ІМ5ЕВТОДОДО 
ULL] 


INSERT INTO table name (column list) VALUES (column values); 


ПППППППППППИПППППППИППППӘОШППИПППППМУБОЦИПППІП 
ОО0О000000000000000000000000000000000 


ОО0О00000000000000 


O'Connor said "Boo" 


ОООДО0000000000001М5Е8Т000000000 


INSERT INTO table name (column name) VALUES ("O'Connor said \ "Воо\""); 


ОООО0000000000000001М5Е8Т7000000000 


INSERT INTO table name (column name) VALUES ( '01'Соппог said "Boo"'); 


ПШШШШМ5ЕКТ Ц 


ООООО001М5ЕВТООООООООО00О00000000000000000000000 
ОООО0000000000000000000000000000000 


Погосегу іпуептогуЦППІППӘ  ПіюПкет namel 
item desc[]item price[]curr ду ПООДОДодорооооророооо 
ШИШЕ 


° ПОООООО0О0000000000 


INSERT ІМТО grocery inventory 
(id, item name, item desc, item price, curr qty) 
VALUES ('1', 'Apples', ‘Beautiful, ripe apples. ', '0.25', 1000); 


• ПООООООДО00000000000000000 


INSERT INTO grocery inventory VALUES ('2', ‘Bunches of бгареѕ', 
"беей1е55 дгаре5.', 2.99', 500); 


ООООО000000000000000000000070Оцегу OK TET 


ООООД001М5ЕВТОДООООООО00000190000000000000000000 
ОО000000000000000000000000ар0000000000000000000000 
ОО00000000000000000%90000 


INSERT INTO grocery inventory VALUES 
(‘Bottled Water (6-pack)', ‘580ml spring water.', 2.29, 250); 


ООО0000000000000 


ERROR 1136: Column count doesn t match value count at row 1 


ППППППППППМУ БОВППППИППИППИППППИППИППППИППГИТТГІІ 
ОО0Музозорро0Оіа оДОО000000000000000000000 


• ДОД ОО000000000 


INSERT INTO grocery inventory (item name, item desc, item price, curr qty) 
VALUES ('Bottled Water (6-pack)', ‘50@ml spring water.', 2.29', 250); 


• ОДОДОДООДОДО0000000000000Д180000МОЗСОООМу5ОС0000 
000000 


INSERT INTO grocery inventory VALUES ('NULL', 'Bottled Water (12-pack)', 
'500т1 spring water. , 4.49, 500); 


ППИПИПИПИПИППогосегу іпуепсогу ЮДО00000000000000 
ОМу5О СОООООДОО0О0000000000000000000000000000000000 
ООО0ОО0000000000000000000000000 


16.4 || ЗЕГЕСТІ || 


ЗЕСЕСТООООООООООООО0ОО0О00000000000000000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
ОПОЗЕСЕСТОПОООООООООООО0ОО0О00000000000000000 


ОДОО5ЕСЕСТОДОД0000 


SELECT expressions and columns FROM table name 
[WHERE some condition is true] 

[ORDER BY some column [ASC | DESC]] 

[LIMIT offset, rows] 


ООО00000000000 


SELECT expressions and columns FROM table name 


ООДО000000РОООО000000000000009госегу, inventoryDE 00 
ОДООД000000000059 800000 


SELECT * FROM grocery inventory; 


ПППогосегу іпмепёогурпоо0000000000000000000000000 
ПППП 


Бал жекке к E P Атена танды ee کا ی‎ s T: acci scs ыты Зно Жағаны ы да + 
| id | item name | item desc | item price | curr qty | 
ов рез a ose eee celestis Ж» Қаға p ceu o Rod dog masa Riad aere sd ee s Кааба кыре ы + 
| 1 | Apples | Beautiful, ripe apples. | @.25 | 1000 | 
| 2 | Bunches of Grapes | Seedless grapes. | 2.99 | 500 | 
| 3 | Bottled Water (6-pack) | 500т1 spring water. | 2.29 | 250 | 
| 4 | Bottled Water (12-pack) | 500т1 spring water. | 4.49 | 500 | 
%----%--------------.-.-..-..-.-.... %--------------.--.-.-......-- %------------ %---------- + 


4 rows in set (9.00 sec) 


ООМУ5ЅОСТООООООООООООООМУу5ЅОСОООООООООО00000000 
ООО00000000000000000Му5ОЦОО0000000000000000000000 
00000000 


ОООООООДОДООООДОДОДООООДОДОООДОДОДОДОДОГ 
дгосегу туепогуПППаПКет_пате[Псигг ағуППП 


SELECT id, item name, curr qty FROM grocery inventory; 


ПППШШИШШП 


E ت د‎ ee ною асылға о ЫН Pies ee ا‎ ds м» + 
| 1d | item_name | curr qty | 
peser nud, icu E а яса + 
| 1 | Apples | 1009 | 
| 2 | Bunches of Grapes | 500 | 
| 3 | Bottled Water (6-pack) | 250 | 
| 4 | Bottled Water (12-pack) | 500 | 
%----%-----------.-..-.-.......... %---------- + 


4 rows in set (0.90 sec) 


16.4.1 || ЗЕГЕСТІ || 


ЗЕСЕСТОООООООООООООООО00000000000000000000000000 
ООООО0О0000000000000000000001900000000000000к Ек 
ВҮрОО00000000000000000000&ет_ nam ep ribi i il] 


SELECT id, item name, curr qty FROM grocery inventory 
ORDER BY item name; 


LILIDIEICIETETETETLTLILI 
ысы ш ыш ш э Re Ere ЖОШ шаты ее ес Ece S Za шешшш ш В + 
| id | item name | curr qty | 
ГИТЕ ——————— desee meia + 
| 1 | Apples | 1000 | 
| 4 | Bottled Water (12-pack) | 500 | 
| 3 | Bottled Water (6-pack) | 250 | 
| 2 | Bunches of Grapes | 500 | 
%----%----------.-.-.-............ %---------- + 


ОООО0О00000000000000000000000000000000000000МУу5ОСО0000000000000. | 
ки лаа лаа Ыз 
ОО000000000000000 


ORDER ВҮПППШШШПШПА5СПЦПШПИПИШЦППАП/ППИИПППОЦПИШИШП 
ОООО00000000000000000000000РЕ5С000000 


SELECT id, item name, curr qty FROM grocery inventory 
ORDER BY item name DESC; 


00000000 
Toa noa ою ар ЭОЕ С ЈЕ Зі? болонка qt ub юна s + 
| id | item name | curr qty | 
РТ ————————— Tee sss Ета + 
| 2 | Bunches of Grapes | 500 | 
| 3 | Bottled Water (6-pack) | 250 | 
| 4 | Bottled Water (12-pack) | 500 | 
| 1 | Apples | 1@@@ | 
%----%----------....-..-....... %---------- + 


4 rows in set (0.00 sec) 


ООООО0000000000000000000000000000000000000000000 
00000000 


16.4.2 [| 


OOUOLIMITOOOUUSELEC ТОООООООООООО0О000А1МІТОДОООО 
ООООО00000000000000000000000000000 


ППогосегу іпмепіогу ПОДОДООО00000000000000Осигг tyr] 
ООДО000010 патеПрачапеїсуДОДОО00000000000000000000000 
ОООО9000000000000000 


SELECT id, item name, curr qty FROM grocery inventory 
ORDER BY curr qty LIMIT 2; 


00000000 


e E a E ын ып З E ا‎ низ + 
| id | item name | curr_qty | 
зон ні ee аск = ee ір ju sasi юною я + 
| 3 | Bottled Water (6-pack) | 250 | 
|2 | Bunches of Grapes | 500 | 


2 rows in set (0.00 sec) 


LIMIT ОООДОООО0О000000000000005ЕБЕСТОДОДОВІМІТОДПОГ 
ОО0О00000000000000000000000000000000000 


ІП5ЕЦЕСТ * FROM grocery inventory ORDER ВУ curr qty 
LIMIT O, 2; 


2 ПБЕ(ЕСТ * FROM grocery inventory ORDER BY curr qty 
LIMIT 2, 2; 


ЗП5ЕТЕСТ * FROM grocery inventory ORDER BY curr qty 
LIMIT 4, 2; 


ОО000000000000000000000000000000000000000000000 
ПППППППППогосегу ІпуептогуПППППӨОПППИПИПИПИПИПӨПИМІТ 
ПШПШ 


HOD Web db p p Ed BODIE DO ETE D 00 WOU 
DEIDIBBICIEIEICIETE]EEM ET ШИП 


16.5 (ПООПОПМНЕКЕ 


ООООО00000000000000000000000000000000УУ/НЕКЕОООО 
ОООО05ЕСЕСТОДОООООООООПУУНЕКЕООООДООООООО 


SELECT expressions and columns FROM table name 
[WHERE some condition is true] 


ОООО0000000000005000000000 


SELECT * FROM grocery inventory WHERE curr qty = 500; 


LULU 
из жы шу в ненна нт елате ноаен фен Я вияш ов юну ан а Какин а еъ вен ж» + 
| id | item name | item desc | item price | curr qty | 
—————Ó—— MD IA lle 
| 2 | Bunches of Grapes | Seedless grapes. | 2.99 | 500 | 
| 4 | Bottled Water (12-pack) | 560ml spring water. | 4.49 | 500 | 
E етс Бес еБносс сБ Peete ————— Е Келеш was wag шош ш 1 


2 rows in set (0.00 sec) 


ОООООО000000000000000УУ/НЕКЕООООООО0ООО0000000000 
ООООО000000000000000000000000000001М5Е8Т700000000 


16.5.1 (МНЕКЕПОООООЦО 


ООООДУУ/НЕКЕДООДОООООООПАОООООО0О0000000000000000 
ООДО0000000000000000000000000000000000000000016-200 
ОО00000000000 


016-1 ДОДОООООДОП 


DM 





ПОООО0ВЕТМЕЕМООООООООООООООООООООООООООООООООО 
ООО000000000000000 


SELECT * FROM grocery inventory WHERE item price BETWEEN 1.50 AND 3.00; 


ООО0000 
E p ами ній CP "IP еке os UR RS III LL + 
| id | item name | item desc | item price | curr qty | 
%----%-----------------....... %-«--------------.--... %------------ %---------- 
| 2 | Bunches of Grapes | Seedless grapes. | 2.99 | 500 | 
| 3 | Bottled Water (6-pack) | 50@ml spring water. | 2.29 | 250 | 
ы. күрер Ис В сб нене ль вна кл жа ак тн Eee Bees + 


2 rows in set (0.00 sec) 


ООООДО00000000000000000УУНЕКЕПОООООООО0О000000000 
АМОПОЕОДОДАМОДОООООООООООООО0О0О00000000090А00000 
ОООО0000000000000001МО000000000000000000 


16.5.2 [ШИКЕ [ШШ 


ПООООООООСМНЕКЕООООООО SU =I IILI III 
ULIILIILILILIWHERELI IILI IILI LI ILICEL III IILI IILI III I 
ОО00000000 


• %—— 000000 
° ИШЕ 


ППИПИПИП Погосегу іпуепсогу ОДОДОДО0О0О0ОАОООО00000 
00000 


SELECT * FROM grocery inventory WHERE item name LIKE 'А%'; 


LILILILILILILI 
|c-——— n |I "TRO зара cT NU MP + 
| id | item name | item desc | item price | curr qty | 
-----4----.-..... I Te pel... + 
| 1 | Apples | Beautiful, ripe apples. | 0.25 | 1900 | 
%----4-----4------%------------.4-...........- exe fee eee ee eee + 
1 row in set (0.00 sec) 
[її] 


ILIIIILIII LIL LILICELI III IILI IILI B INA RY OOOO | 
ЕНЕЕЕШЕ x 


16.6 [I 


ООООО0000000000000000000000000000000000000000000 
HUUUUUS ELEC ТОООДООООООО0О00000000000000 


ОДОД00000йпмїєОсоїогДДОООООО0000005ЕБЕСТОДОДОДОО 
ООО00000000000000 


SELECT * FROM fruit; 


ОДО0000000000 
од aE ES + 
| id | fruitname | 
+----+----------- + 
| 1 | apple | 
| 2 | огапде | 
| 3 | grape | 
| 4 | banana | 
+----+----------- T 


4 rows in set (0.90 sec) 


SELECT * FROM color; 


ООО0000000000 
рон a ачаа Мор ш + 
| id | colorname | 
Es бара в aa ee + 
| 1 | red | 
| 2 | orange | 
| 3 | purple | 
| 4 | yellow | 
%----%----------- + 


4 rows in set (0.90 sec) 


ООООО000000000000005Е2С-ЕС ТОООООООО000000000000000 
ОДОДОООООДО05 ЕСЕСТОДОРАЕОМООДООЇ ruit соїогоДООО0000000 
ООООО000000000000000005ЕСЕСТОДО 


SELECT * FROM fruit, color; 


ОО000000000000000 


du esp кра ME ks Pausa sq = ee + 
| id | fruitname | id | colorname | 
dub e pis EVENS 

| 1 | apple | 1 | red | 
| 2 | огапде | 1 | red | 
| 3 | grape | 1 | red | 
| 4 | banana | 1 | red | 
| 1 | apple | 2 | orange | 
| 2 | orange | 2 | orange | 
| 3 | grape | 2 | orange | 
| 4 | banana | 2 | orange | 
| 1 | apple | 3 | ригрје | 
| 2 | огапде | 3 | ригрје | 
| 3 | дгаре | 3 | ригрје | 
| 4 | рапапа | 3 | ригрје | 
| 1 | аррје | 4 | yellow | 
| 2 | огапде | 4 | yellow | 
| 3 | дгаре | 4 | yellow | 
| 4 | рапапа | 4 | yellow | 
іы ан ва See eres Е sampah + 


16 rows in set (0.00 sec) 


16000000000000000000000 00000 (ee ter 00000000000 
fruit[| ETIDDULDUFrurt О 4 ПО00Осогог EID 4 ПП ii] 1e II IL 


ООООО0000000000000000У/НЕКЕОООООООО0О0000000000 
гиїісоїогГДОООО0Д0000000000190000000000їтичїєпатеб 
соїогпатербООО000000000000000----ООО0О0000000000000 
ОО0000000000000 


ООО0О0000000000000000000000000 


tablename,fieldname 


П000000000Ір000#гипате[соіогпатеро000000500 


SELECT fruitname, colorname ҒНОМ fruit, color WHERE fruit.id = color.id; 


ООО000000000000000000 


| Pera Ses шк бош б + 
| fruitname | colorname | 


n [asas b deeds ий + 
| арр1е | red | 
| orange | orange | 
| grape | purple | 
| banana | yellow | 
+----------- Ы----------- + 


4 rows in set (0,00 sec) 


ООО0О000000000000000000000000000000000000000 


SELECT id, fruitname, colorname FROM fruit, color 
WHERE fruit.id = color.id; 


ОО00000000000 


ERROR 1052: Column: 'id' in field list is ambiguous 


ОД000097гитОДоріБ0000000 


SELECT fruit.id, fruitname, colorname FROM fruit, 
color WHERE fruit.id = color.id; 


ООО0000000000 
фан вв ні рете утас + 
| id | fruitname | colorname | 
Tercers ТРГ |n + 
| 1 | apple | red | 
| 2 | orange | orange | 
| 3 | grape | purple | 
| 4 | banana | yellow | 
+------ рон ---------.--- + 


4 rows in set (0,00 sec) 


ООООО0О0000000000005ЕС-ЕС ТОООООООО000000/01МО0000 
ОО05О:0000000000000000000000 


16.6.1 ПЦІОІМ 


ОМуЗОРДПОООО0ОДО МОДООООООООООООООДО000000000000 
О0000йгинсотогДОДОШОТМОДІМ N ER. )ОІМОДОДОДОДООООДО 
ПОДІММЕВ )ОТМОДООООО005О0Є00000000 


SELECT fruitname, colorname FROM fruit 
INNER JOIN color ON fruit.id = color.id; 


000000 
پا‎ She et eus асы fre dans + 
| fruitname | colorname | 
Быш шылы БЕ Кекте + 
| арр1е | red | 
| orange | orange | 
| grape | purple | 
| banana | yellow | 
+----------- ј- ~ + - + - + + + + - + 


4 rows in set (0,00 sec) 


ОМПОООООООООО0 УУНЕКЕПОООООООООДПОМУ5ОГМОДОЇОПО 
ООДОО0О00000ОМПООООООО 0000000 УУНЕКЕООООДО00000000 
ООО00000000000000 


ПОООООЈОМОООСЕР Т ЈОМОООСЕРТ )О|МОООДОООООДО0000О 
ПОООбО0000000000000000000000000000000000000000 
master патер00000000000ета!00Ета!О00етано00000 
000000 авіег паптепбродроОО000Т90000000000000 


decas ee be juae EE ی‎ Кешн erat + 
| name id | firstname | lastname | 
Баян es Е а стени и ази ы РЕ + 
| 1 | John | Smith | 
| 2 | Jane | Smith | 
| 3 | Jimbo | Jones | 
| 4 | Andy | Smith | 
| 5 | Chris | Jones | 
| 6 | Anna | Bell | 
| 7 | Jimmy | Carr | 
| 8 | Albert | Smith | 
| 9 | Јоћп | Doe | 
%--------- Һ----------- %---------- + 
%--------- Ы------------------- + 
| name id | email | 
Кызыке osc Қалман ara aos enak aza ee + 
| 2 | Jsmith@jsmith.com | 
| 6 | annabell@aol.com | 
| 9 | jdoe@yahoo.com | 
а а ан Ee Mas ae ukat a ge E + 


ПОООООООСЕР T ЈОІҸОБО0000000етано00000000000000 
ОДОО0Е планіодоордододосооо 


SELECT firstname, lastname, email FROM master name 
LEFT JOIN email ON master name.name id - email.name id; 


ПОСЕРТ JOTNDJCIDDIEIEICUEILU 


ose a کرک‎ Me | үч үзүү DE + 
| firstname | lastname | email | 
%----------- ----------- %------------------- + 
| Јоћп | Smith | | 
| Jane | Smith | jsmithaàjsmith.com | 
| Jimbo | Jones | | 
| Andy | Smith | | 
| Chris | Jones | | 
| Anna | Bell | annabell@aol.com | 
| Jimmy | Carr | | 
| Albert | Smith | | 
| John | Doe | jdoe&8yahoo.com | 
Кеш шаршен ы e Je ————— уы + 
9 rows in set (0,00 sec) 


ПОВІСНТ ЈОМООООСЕРТ )ОТМОДОООООООДО0000000000 
RIGHT )ОІМОДООДОООООДОО0О000000000000000000000000 
master пате[ета!00000ета!0003з000таѕег namei) 
90000000Опазіег патедррброз ООДОзодородроодод 


SELECT firstname, lastname, email FROM master name 
RIGHT JOIN email ON master name.name id - email.name id; 


ОО000000000000 


одна оба — св Е ЛГ — — + 


| firstname | lastname | email | 

| ез zs отугу E нам + 

| Чапа | Smith | jemithaàjsmith.com | 

| Anna | Bell | annabell@aol.cam | 

| John | Doe | jdoe&yahoo.com | 
t 


З rows in set (0.00 sec) 


МУ-БОСГППИИИППППОМПИПИППППИИППИПППИПИППСКО55 
JOIN[JSTRAIGHT JOIN[]NATURAL |ОМППТОММПППППГ 
http://dev.mysgl.com/doc/refman/5.5/en/join.html []MySQL[] 
ПОООСОООООООООООООООООООО!ЧООО5ОЦТОООООООООООООО 


16.6.2 ПОГ 


ОООО0000000000000056000005ЕЕЕСТОООО00000000 
ОООООО0000000001МОДОООООООООО0000000000000000000000 
0000000 


ОО000000000000000 


SELECT expressions апа columns FROM table name WHERE somecolumn = (SUBQUERY); 


ПООООООООРРАТЕЦРЕСЕ ТЕПООООООООООЦ 


DELETE FROM table name WHERE somecolumn = (SUBQUERY); 


[| 


UPDATE table name SET somecolumn = 'something' WHERE somecolumn = (SUBQUERY); 


ПОООООООООООО$ЕТЕСТОИМЗЕВТОУРРАТЕПОЕТЕТЕ$ЕТОО00000000000000 x 
0000000 x 


ОООДОО00000000000УУНЕКЕДОООООООДО-ОД0О00002- 0000 
ОДООДОО0000000001МОД000000 


О00000000000000пазіег патердудДеплан ор оДООЄтаїі 
00000000 


SELECT firstname, lastname FROM master name 
WHERE name id IN (SELECT name id FROM email}; 


ООО000000000000 
+— — — — — = +— — — — = + 
| firstname | lastname | 
сызы зага снн жшн эрш жешн + 
| Фапе | Smith | 
| Аппа | Ве11 | 
| John | Doe | 
Beso Es + 


3 rows in set (0.00 sec) 


ЕНЕНЕЕЕШЕШЕЕЕНЕШЕШЕЕШЕЕЕЕ 
http://dev.mysql.com/doc/refman/ 5.5/en/subqueries.html [] 


Му5О 00000000 


16.7 ПІЧОРОАТЕ ЦП 


ОРОАТЕЦООООООООООООООООООООООООО5ОТОООВОО 
ОРБАТЕДПООДОДО 


UPDATE table name 

SET columni- new value , 
column2='new value2' 

[WHERE some condition is true] 


ОО0О0000000000000000000000000000000000000000000 
ОО0000000000000000000000000000000#и00000001р000 
ОДО00000000п per]rottenr]E] 


e s pade za a a= sees ë < qeee9-- = + 
| id | fruit name | status | 


РЕ RC as a Ie 1 
| 1 | apple | ripe | 
| 2 | orange | rotten | 
| З | grape | ripe | 
| 4 | banana | rotten | 
+----+------------ +-------- + 


4 rows in set (0.00 sec) 


IILI Er pe D ICT TL 


UPDATE fruit SET status - 'ripe'; 


ООО0000000000000000 


Query OK, 2 rows affected (0.00 sec) 
Rows matched: 4 Changed: 2 Warnings: 9 


ОООООДО0000000000000000000чегу ОКООООООООО000000 
ОООО000000000000000000000000000000000000000000200 
ОООФО000000000000000000000000000000000000000000000 
ООО00О000000000000000000 


ОООО0000000000000000000000000000000000000000000 
ООООО0000000007/ 9гаре"ПДО00000000000009РФБАТЕПООООО 
ОО00000000000000 


UPDATE fruit SET fruit name = 'grape'; 


ОО000000000000000 


Query OK, 4 rows affected (0.00 sec) 
Rows matched: 4 Changed: 4 Warnings: 0 


ОО000000000000000004000000000000#то 000000 


1 | дгаре | ripe | 
2 | grape | ripe | 
3 | grape | ripe | 
4 | grape | ripe | 


4 rows in set (0.00 sec) 


ОО000000000009гагарепрдоООО0000000000000000000000 
ОДООДОО00000000009РРАТЕООООООООООО0ООООО0О000000000000 
ОО00000009 гарепоооооообобобобм у НЕКЕОООООКа 
fruit nameD] lab pp p TEL 


16.7.1 ПППУРОАТЕ 


DELIBEICIE]]UPDAT ETTEJCIEIEjW RH ERE TCIETEICIEIDEIEIEILIU PD AT EL UO 
ОДУУНЕВЕПООО5ЕНЕС ТОПООО ОМУНЕКЕДОООДОООООООО00000000 
ООДОО000000000000000КХП0АМОП 


ОрігмйєдОД00Одгареродод040000000000000000000000 
дгаррепдрогарерроДОПООО УРФАТЕДОДОООО 


UPDATE fruit SET fruit name = 'grape' WHERE fruit пате = 'grappe'; 


ОО0О0000000000000000000000000000 


Query OK, 1 row affected (0.00 sec) 
Rows matched: 1 Changed: 1 Warnings: 0 


Пор а НООДОДО0Д00О00000000000000000 


SELECT * FROM fruit; 


LEISELEC TETBIEIEIDIILIUL] 
Joas lS Peis ees Sr + 
| id | fruit name | status | 
Е ивана Шаш + 
| 1 | apple | ripe | 
| 2 | pear | ripe | 
| 3 | banana | ripe | 
| 4 | угаре | ripe | 
Poanes ss se eme pee элаз + 


4 rows in set (@,@@ sec) 


16.7.2 [JJUPDATEQUQUUUUUU 


ОРОАТЕПОООООДОД0О0О0О0О00000000000000000 
grocery іпмепіогу [00000000000000 


| -"——————"————— dus oe S SUM eue oe ue та Блат жэ тора л ая оз гек Беја іе + 
| id | item name | item desc | item price | curr qty | 
l| EEE one ee ae ee Рт каке lp | m + 
| 1 | Apples | Beautiful, ripe apples. | 9.25 | 1000 | 
| 2 | Bunches of Grapes | Seedless grapes. | 2.99 | 500 | 
| 3 | Bottled Water (6-pack) | 5@@т1 spring water. | 2.29 | 250 | 
| 4 | Bottled Water (12-pack) | 500ml spring water. | 4.49 | 500 | 
| 5 | Bananas | Bunches, green. | 1.99 | 150 | 
| 6 | Реаг5 | Anjou, nice апа sweet. | 0.5 | 500 | 
| 7 | Avocado | Large Haas variety. | 0.99 | 750 | 
Бы ———————— Pec ee eee ee wee ee ee clas Ei + 


7 rows in set (0.00 sec) 


О000000000000000000%а= О0имепеогудрдобобобобоо о 
О00сигг ағу ДООО000000000000000000000000000000002000 
OOL 


UPDATE grocery inventory SET curr qty = curr qty - 1 WHERE id = 1; 


ПООсит_асупороп9 9 9p i dp III! 


SELECT * FROM grocery inventory; 


ПОЗЕСЕСТООООООО00О000000000 


IT ж Шш кю зріла іх зоною Зо s вн ні шш рів с ак зі кез лыш Fels Sams нала die gai шшш s и + 
| id | item name | item desc | item price | curr qty | 
E خخ‎ esol aa asas eae жн + 
| 1 | Apples | Beautiful, ripe apples. | 2.25 | 999 | 
| 2 | Bunches ої Grapes | Seedless grapes. | 2.99 | 500 | 
| З | Bottled Water (6-pack) | 500ml spring water. | 2.29 | 250 | 
| 4 | Bottled Water (12-pack) | 580ml spring water. | 4.49 | 500 | 
| 5 | Bananas | Bunches, green. | 1.99 | 150 | 
| 6 | Pears | Anjou, nice and sweet. | 0.5 | 500 | 
| 7 | Avocado | Large Haas variety. | 0.99 | 750 | 
ee ее > %-----------------...-....- Һ------------ %---------- + 


7 rows in set (0.00 sec) 


16.8 ППЕКЕРІАСЕТ І | 


ПППИПППППППИПКЕРІ АСЕППППИППІМБЕКТІГІП 


REPLACE INTO table name (column list) VALUES (column values); 


РЕРСАСЕПООООООО0ООО0ООО0000000000000000000000000 
ОООО000000000000000000000000000000000 


КЕРАСЕПППМУЗОЦЈАМ5! S ОЦОПОПОООООООО0000рЕСЕТЕОПОООДІМ5ЕВТОДОО 
ОООД00000000000000000000000000 u 


ПЦПдгосегу_їпуепїогуЦПЦППППЦППППАрр!еЦПППП 


REPLACE INTO grocery inventory VALUES 
(1, ‘Granny Smith Apples', ‘Sweet!', '0.50', 1000); 


0000000 


Query ОК, 2 rows affected (0.00 sec) 


О00000000000000*2 rows аї'естеа"рдДр0ОДОДОІАССГО 
grocery іпмепіогу ДО ДООДОДОДОДО00000000000000000002000 
ОООО05ЕСЕСТООООООООООО0000000000 


Кешш ше шеш шаш ны НОР: ад нь шша ЖАҒЫ ОР Р шошо Pe НС ама шош Якої а E + 
| id | item name | item desc | item price | curr qty | 
— Ее атыз ПОЛЕ ЕЕ a р НІЛУ E CE oe ee we яко ا ا ا‎ и E шкы й 

| 1 | Granny Smith Apples | Sweet! | 9.50 | 1000 | 
| 2 | Bunches of Grapes | Seedless grapes. | 2.99 | 500 | 
| 3 | Bottled Water (6-pack) | 580ml spring water. | 2.29 | 250 | 
|4 | Bottled Water (12-pack) | 5@@т1 spring water. | 4.49 | 500 | 
| 5 | Bananas | Bunches, green. | 1.99 | 150 | 
| 6 | Pears | Anjou, nice and sweet. | 0.5 | 500 | 
| 7 | Avocado | Large Haas variety. | 0.99 | 750 | 
Ч Cr————————————— Бен «емесе кіна е бос Foer асан Ене ДЕ ел eee + 


7 rows in set (0.00 sec) 


ООООООКЕРСАСЕПООДООООООООО0ОООО0000000000000000 
ООО0О00000000000000000000 


16.9 ППОЕТЕТЕГІІ | 


DELE ТЕППОООООО 


DELETE FROM table пате 
[WHERE some condition is true] 
[LIMIT rows] 


ООООРЕСЕТЕПООООООООООООООО ЕСЕ ТЕСОООООДОО00000 
О000000000000000000#ти00огарербо0000000000000000 
ООООО000000000000РЕСЕТЕПООООООО0000000 


ОО009РгисОДОоД00000000 


ru = SU S S ен T. =< Sasa: эв + 
| id | fruit name | status | 
Tessa و‎ жазаа nukun аена + 
1 | арр1е | ripe | 
2 | реаг | rotten | 
3 | banana | ripe | 

4 | дгаре | rotten | 
%----%----------.. %-------- + 
4 rows in set (0.00 sec) 


ООО000000000000000 


DELETE FROM fruit; 


LEIDIBIOIDEIEIDOILI LIS ELEC T ETETEDERIEI DID EIE CIO DID EIE CI III! 


SELECT * FROM fruit; 
ПООО СОООДООбОДО00000 

Empty set (0.00 sec) 

ПООРЕСЕТЕ 
ПООООРЕСЕ ТЕПОООООО5ЕНЕСТПОРОАТЕПОООДОО0000000 


МУНЕКЕПОДООО ОООООООООООО00ОО0000000000000000000000 
000000 


ОДОД000000ймї00000000говсепДодоООбОЗ0000 


DELETE FROM fruit WHERE status = 'rotten'; 


ОО0О00000000000000000000 


Query OK, 2 rows affected (0.900 sec) 


LIETLILILILILILI 
eigene КЕ НЕЕ deese + 
| id | fruit name | status | 
qose тенеке US Ex mex + 
| 1 | apple | гіре | 
| 3 | banana | ripe | 
En n + 


2 rows in set (@,@@ sec) 


ООООООРЕСЕТЕООДОДОКОЕВ ВУПОПОООВОВОВОЕВ ВҮрП00 
ПООООООООВЕ СЕ ТЕПОО 


DELETE FROM table name 

[WHERE some condition is true] 
[ORDER BY some column [ASC | DESC]] 
[LIMIT rows] 


ООО00000007 О00000000000000"П0КРОЕК вудороообооц 
ОО0000000000 


у000000000Пассез5 leg nb nib a i III! 


Тола Ра нара eee cei ыда бод данды + 
| id | date accessed | username | 
c-r E due asd + 
| 1 | 2012-01-06 06:09:13 | johndoe | 
| 2 | 2012-01-06 06:99:22 | janedoe | 
| 3 | 2012-01-06 06:09:39 | jsmith | 
| 4 | 2012-01-06 06:09:44 | mikew | 
%----%---------------....-. Һ---------- + 


4 rows in set (0.00 sec) 


ООООД0ОО0Д00000кРЕК BYTTEROIEIBIDIDEIEI CILE TM T T O00 
0000000 


DELETE FROM access log ORDER BY date accessed DESC LIMIT 1; 


ПЦПассе55_10ОППШПППППППППЗПШШИШШП 


SELECT * FROM access log; 


ШЕШЕНЕ 


2012-01-06 06:09:22 | janedoe | 
2012-01-96 06:09:39 | jsmith | 
2012-01-06 06:09:44 | mikew | 


З rows in set (0.00 sec) 


16.10 MySQL 


МУ5ЗОРООООООДООО0000000000000000005Е СЕС ТОДООООО 
ОООО0000000000000000000000000000000000000000000000 
SELECT ILILILILILILILILI I IMySQLIII I О00000000000000000000000 
[http://dev.mysql.com/doc/refman/5.5/en/ string- 
functions.html MySQL 000 


16.10.1 [ID 


ООООб00000000000000000000000000000000-6К26МеТНОГ 
OCTET LENGTH()JCHAR ЦЕМСТНОДСНАВАСТЕВ ЕЕМСТН()П 


ООСН ОООО ОООО ОООО 


SELECT LENGTH('This is cool!'); 


0000000 


1 row in set (@.@@ sec) 


О00000СОМСАТ(Ј0000000000000000000000000 


SELECT СОМСАТ( "Му, 'S', 'QL'); 


ОО0000000000 
| CONCAT('My^, 181, "QL') | 
Ce om | 


1 row in set (@.@@ sec) 


ОО000000000000000000000000пгѕёпатер0аѕілатеП 
О0000000000000пгѕпатер00аѕёпатеріоо00000000000000 
ОО000000000000000000000000 


SELECT CONCAT(firstname, lastname) FROM master name; 


00000 


| JohnSmith | 
| JaneSmith | 
| JimboJones | 
| AndySmith | 
| ChrisJones | 
| AnnaBell | 
| JimmyCarr | 
| AlbertSmith | 
| JohnDoe | 


9 rows in set (0.00 sec) 





ОООО0О0000000000000000000000000000000000000МУЗООД000000000 
СОМСАТОООООООО ОО00000 


SELECT CONCAT('firstname', 'lastname' ) FROM master name; 


О00000000 


| CONCAT('firstname', 'lastname') | 


| firstnamelastname | 
| firstnamelastname | 
| firstnamelastname | 
| firstnamelastname | 
| firstnamelastname | 
| firstnamelastname | 
| firstnamelastname | 
| firstnamelastname | 
| firstnamelastname | 


ООООО00000000000СОМСАТ()О0000000000000000000 


О000000СОМСАТ_\МУ5()0000000000000000000000000000 
ULL] 


SELECT CONCAT WS(' ', firstname, lastname) FROM master name; 


ОО0000000000 


| CONCAT WS(' ', firstname, lastname) | 
+------------------------------------- + 
| John Smith | 
| Jane Smith | 
| Jimbo Jones | 
| Andy Smith | 
| Chris Jones | 
| Anna Bell | 
| Jimmy Carr | 
| Albert Smith | 
| John Doe | 
+ 


9 rows in set (0.00 sec) 


ООДОО000000000000А5О0000000000000000 


SELECT CONCAT WS(' ', firstname, lastname) AS fullname FROM master name; 


ОД00000000000000 
а 71 
ом 1 


| 

| Jane Smith | 
| Jimbo Jones | 
| Andy Smith | 
| Chris Jones | 
| Anna Bell | 
| Jimmy Carr | 
| Albert Smith | 
| John Doe | 
+ 


9 rows in set (0.09 sec) 


16.10.2 [lI ILL 


Му -БОЦТПППИППИПИИПИПИПИППИПИППППИПИППКТВІМОП 
СТАТМООДООД0О00000000000000 


SELECT RTRIM('stringstring ШЕ 


ООО00000000000000000000 


1 row in set (@.@@ sec) 


СТВІМОДОДОДОДОДООООО 


SELECT LTRIM(' stringstring'); 


ООО0О000000000000000000000 


МЕ ap hor зық ы айар a G и + 
| LTRIM(' stringstring') | 
%-------------.-------.-.. + 
| stringstring | 
E a a E аа В + 


1 row in set (9.00 sec) 


ООООО00000000000000000000000000000000000000 
магсһаг000000000000000000000000000000000000000000 
ОО00ТАІМ(Ј000000000000000000000Х000000хХХпееаіеххх 
ОО000000000 


SELECT TRIM(LEADING 'X' FROM 'XXXneedleXXX'); 


ОДО00000000 
лала Ê В c dur Bee inviter = eu Eo === + 
| TRIM(LEADING 'X' FROM 'XXXneedleXXX') | 
%--------------------....--.............- + 
| needleXXX | 
| о о ооо a as + 


1 row in set (0.00 sec) 


HOUT ВАПІМОДООДОО0000000 


SELECT TRIM(TRAILING 'X' FROM 'XXXneedleXXX'); 


ОО0000000000 


1 row іп set (0.00 sec) 


ОООО00СЕАРІМОД ТВАТЬІМОГООООО0ОО0ОО0000000 


SELECT TRIM('X' FROM 'XXXneedleXXX' ); 


00000000 


1 row in set (0.00 sec) 


ПЕТКІМОПИТЕІМОППИПИППППКРАРОГПЕРАРОПИПИПИПППГП 
ООООО0Д000000000000000000000000000000000000000000000 
ОДООДО00000000000000000000000000000000000Х0000000 
пееатеррдоД00002000000000000000 


SELECT RPAD('needle', 18, Х'); 


00000 
E= =S ки онов лишсе eS See жое шла ОБО» + 
| RPAD('needle 10, 'Х') | 
илыш rm + 
| needleXXXX | 


row in set (9.00 sec) 


16.10.3 ПОПОВ 


ООДООО000000000000000000000000САТЕСОДООО0О0000 
ООДО0О0000000000000000000000праузсаск )ООпееате рОО000 


SELECT LOCATE( 'needle', 'haystackneedlehaystack'); 


ОО00000000 
tiie о ЕЕ “—_______---__ ваң е + 
| LOCATE('needle', 'haystackneedlehaystack') | 
ил wg eere жар ШШ ані азыгы D a ы алырга нене + 
| 9 | 
| ———————————————" + 


1 row in set (0.00 sec) 


О000Опееатерддо0Д090О00С0О0000000000000000000 
МУуЗОСОДОДОДО0 


ЦГОСАТЕСООДООООООООО00000030000000ОйааузсаєкоДО09000 
ОО пееате ПДОДО000000900000000Опееатедрд0900000000000 
ООДОО00000000000000000000 


16.10.4 [JJ 


ООООО0000000000000000000000000000000000000000000 
ОДОО0585 ТКІМСОДОДОДОДО000Музогоррзод0р00002000 


SELECT SUBSTRING("MySQL", 2, 3); 


UUW 
E Т" + 
| SUBSTRING("MySQL", 2, 3) | 
cl SDSS CID + 
| уза | 
Ы------------------«-----..-.. + 


1 row іп set (9.00 sec) 


ОДОООО00О000000000000000Ц-;2РТО0ВІЄНТОДОООДООО 


SELECT LEFT("MySQL', 2); 


ОО00000000 


1 row in set (0.00 sec) 


ООООДДОВІСНТОДОООДОД 


SELECT RIGHT("MySGL", 3); 


00000000 


1 row in set (0.00 sec) 


ООООО000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000000000000000 
ОДОХ ХХ ХАЙ У 2 ПООООДОО0000000000000000000000000 
ZZ) ОООООО000000000000В12НТОООДО00О000000000000000000 
0000 


16.10.5 ПОПОВ 


ООООО000000000000000000000000000000005960000000 
ООО00000000000000000000 


Му5ОШІ САЗЕОПОСАБЕОДООООДО IILI LI LIL I II 


SELECT LCASE('MYSQL'); 
OULU 


| LCASE('MYSQL ') | 
eee ee ече - 
| mysql | 
оне + 
1 row in set (0.00 sec) 


ОО000000000000000 


SELECT UCASE( "пу541'); 
ОО00000000000 


| UCASE('mysql') | 
эла жа Жала ағалы жый за uN - 
| MYSQL | 
Һ---------------- + 


1 row in set (0.00 sec) 


ПИШПШИПШШПМУ5О Г ППППППППППППППППППППППППППППЇ! CASEOnUCASEO 000 x 
ооовоооовооооооооооововооооооовооооовооооовооооововооооооооо | 


ООО000000000000000000000000000 


SELECT UCASE(lastname) FROM master name; 


ООО0000000000000000 


UCASE(lastname) | 


| 
| 
| 
| 
| 
| 
SMITH | 
| 
| 
+ 


9 rows in set (0.00 sec) 


ОДОООО00О000000КЕРЕАТОДОДООО0ОО0О0ОО00О0000000000 
0000000 


SELECT REPEAT("bowwow", 4); 


ОО000000000 
rrr + 
| REPEAT("bowwow", 4) | 
%Ж----------------------.--. + 
| bowwowbowwowbowwowbowwow | 
T 00S + 


1 row in set (9,00 sec) 


КЕРГАСЕ()00000000000000000000000000000000 


SELECT КЕРІАСЕ( Боммомбоммомбомчомбомчом', 'wow', 'WOW'); 


IILI IILI III! 
| ————— -___|-=—_-—_ -- о Шен ме es + 
| REPLACE( bowwowbowwowbowwowbowwow', ‘wow', МОЛ) | 
———————— E——— + 
| bowWOWbowWOWDowWOWD owWOW | 
E РНЕ Е DEICIDE ODES ен S a us tu БР + 


1 row in set (2.00 sec) 


16.11 ПМуУБОГГТТТППИПИПП 


МУ5О СООООООО0О00000005ЕСЕСТОООООООООО0О0О00000000 
ООООО000000000000000000000000000000000000000000 


ОООО0000000000000000000000000000000000МУ5ОСО000 


ОООООООООООООООООООООПОРЕЄр.// Лем. плузді.сопл/дос/ 
refman/5.0/en/date-and-time-functions.html ЏМузОЦ ПЦ 


16.11.1 (ULL 


DAYOFWEEK([IWWEEKDAY()[I[ II IILI IILI LI LIL II IL 
ООО0О00000000000000000000000000 


ОДООРАУОРМ/ЕЕКОДОДООДОДО0Д0О00000010000000000000 
00000 7000000 


SELECT DAYOFWEEK( 2012-01-99"); 


ОО0000000000 


1 row іп set (9.00 sec) 


000002006П01090000000200000000000000У/Е2КОАУМО0Д 
ООООО000000000000000000000000000 


1 row in set (0.00 sec) 


ППППП2006ЛІПӘПППИПППОПППУҒЕЕКРАТОППИПИПИИПИПП 
ООООД90рООО0000000000000600009000000000000000 


РАҮОҒМОМТН()00АҮОҒҮЕАК(О0000000000000000 
РАҮОЕМОМТН()00000001031000АҮОҒҮЕАК()0000103660000 


ПППП 


SELECT DAYOFMONTH('2012-91-09'); 


ОО0000000000 


1 row іп set (9.00 sec) 


ОО00000000 


SELECT DAYOFYEAR{ 2012-01-09"); 


ОО0000000000 


1 row in set (9.00 sec) 


ООООО0000000000000000000000000000000000000000000 
ООООДООДУМНЕКЕДДОООООООООООООООО0ОО00000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
000000 


ОООО00000000000000000000000000000000000000 


SELECT COUNT(id) FROM orders WHERE DAYOFWEEK(date ordered) « 4; 


SELECT COUNT(id) FROM orders WHERE DAYOFWEEK(date ordered) > 3; 


ООРАУОРМОМ'ТТНОДОООДООООДОООДООО0ООО0000000000000 
SELECT COUNT(id) FROM orders WHERE DAYOFMONTH(date ordered) < 16; 


SELECT COUNT(id) FROM orders WHERE DAYOFMONTH(date ordered) » 15; 


О0000АҮМАМЕ()О0000000000000000000000000000 


SELECT ОАҮМАМЕ (даће ordered) FROM orders; 


ОО0000000000 


Thursday | 
Monday | 
Thursday | 
Thursday | 
Wednesday | 
Thursday | 
Sunday | 
Sunday | 


8 rows in set (0.00 sec) 


ООООДОООДУ/НЕКЕПОООДОПДОВОЕВ ВҮПОВОО00000000 


SELECT DAYNAME(date ordered) FROM orders ORDER BY DAYOFWEEK(date ordered); 


16.11.2 [IJI 


ОООДО000000000Му5ОСПОб00000000000000 
ОАУОРУУЕЕКОПОАУМАМЕОПДОДОМОМТНООПМОМТНМАМЕ(ПО 


ООО0000000000000000000000000 


SELECT MONTH('2012-01-09'), MONTHNAME( 2912-01-09); 


ОО0000000000 


рант Ышш ыы ае E edere bue паль ГӨ + 
| MONTH('2012-01-09') | МОМТНМАМЕ ( 2012-01-09!) | 
%----------------..--. %------------------------. + 
| 1 | January | 
Қазым E ағала E таса» О eee жатан + 


1 row in set {@.@@ sec) 


огаег ДОМОМ ТТНМАМЕО ОООДОДОДООООДО0О000000000 


| Мометрег | 
| Мометрег | 
| Мометрег | 
| Мометрег | 
| Мометрег | 
| Мометрег | 
| Мометрег | 
| October | 


8 rows in set (0.00 sec) 


[0000515 ПІМСТОДОО0000000000000 


SELECT DISTINCT MONTHNAME(date ordered) FROM orders; 


О00000000000 
——ÓM—À——ÁM—— aa Ë + 
| MONTHNAME (date ordered) | 
Eel OS E sasata а Eius EE SS + 
| November | 
| October | 
utes pole НИ ae E ins + 


2 rows in set (0,00 sec) 


ОДОДОДУЕАВСООООД00О00000000000 


SELECT DISTINCT YEAR(date ordered) FROM orders; 


ОО0000000000 


| 2811 | 


1 row in set (0.00 sec) 


16.11.3 ППП 


ОООО0000000000000000000000002 А00000000000000000 
00000530000020010012030000000 


SELECT DAYNAME( 2001-12-30); 
ОО0000000000 


| ОАУМАМЕ ( 2001-12-30!) | 
Vite, aie ee нн ль Өз ате алија + 


| Зипдау | 
eee рек аж ЮА + 


1 row in set (0.00 sec) 


00000020010012)30000000053000000 


SELECT WEEK( 2001-12-30"); 


ОО0О00000000000000000 


Кы ай E ——— + 
| WEEK('2001-12-30') | 
Pama gsm h ae w Sea wamani ars h вий + 
| 53 | 
Һ----------------..... + 


1 row in set (0.00 sec) 


053000120300012031000000020020000002010000 


ООО0О0000000000000000000000000000000000000000000 
ООО00010000000000000000000000000000120300002001110 
5200000001203 10005 2 9010053000000 


SELECT WEEK( '2001-12-30',1); 


ОО0000000000 


| | 
lc + 


1 row in set (0.00 sec) 


0000000 


SELECT WEEK( '2001-12-31',1); 


0000000 


1 row in set (0.00 sec) 


16.11.4 [I 


ОО0О0000000000000000000000000000000000000000000 
ООООД0О000000000000000000000000НОЧА00МІМОТЕОО 
ЗЕСОМООДНОЧЕ ОДОДООД000000000002000МІМОТЕОП 
ЗЕСОМО00000005900Ц 


00000 


SELECT HOUR('2012-01-09 07:27:49') AS hour, 
MINUTE('2012-01-09 07:27:49') AS minute, 
SECOND('2012-01-09 07:27:49') AS second; 


0000000000008 
| hese | ння | кішік | 
| 7| 27| | 


1 row in set (0.00 sec) 


ОООО00000000000000000000000000000000000000000 
CONCAT _МУ5()000000000*:"000000000000000000 


SELECT CONCAT WS(':',HOUR('2012-01-09 07:27:49'), 
MINUTE('2012-01-09 07:27:49')) AS sample time; 


ОО0000000000 


1 row in set (0,00 sec) 


16.11.5 [IIMySQLII DULL 


РАТЕ _РОКМАТ()ОО00000000000000000000000000000000 
ПППППИППППИПРАТЕ РОВМАТОДОДОДД 


DATE FORMAT ( дате ,Тогтат) 


01 6-200000000000 


016-2 DATE РОКМАТ() 0000000 


эр 


О0000000000059П 
[0000000900590 
12Q0000000hh:mmi:ss [АР] МО 


2 АППООООООАћ: га па :55 
м 





О00000000000002:0200000000%һ0%000000000000000 
ПИШШШШШШШШШШ: ШШШ 


SELECT DATE FORMAT('2012-01-09 02:02:00', '%h:%i') AS sample time; 


ОО0000000000 


1 row іп set (0.00 sec) 


ПППППИППППРАТЕ РОАМАТОДООООО0ООДОО0ОО0Д000000000 
000000 


SELECT DATE FORMAT('2012-01-09', '%W, ЗМ 560, %Ү') AS sample time; 


ОО0000000000 


: row in set (0.00 sec) 


0000000000000000000№9\\/()000000000000000000 


SELECT DATE FORMAT(NOW(),'*9W the %0 of %М, %Y 
around %1 o'clock %р') AS sample time; 


ОО0000000000 


| row in set (0.04 sec) 


ООО0О0000000000000000000000000000000000 
16.11.6 ПОМуз ОС ПОП 


МУуЗОРДПОДО ОООООООО00О000000Му 5О0ЄПОООД00ОРНРеОДОДОП 
ООООООООООООООООООО0ОрАТЕ ADD OLJDATE SUB 0000000000 
00000000 


DATE ADD(date,INTERVAL value type) 


DATE SUB(date,INTERVAL value type) 


П16-ЗЦЦПШШИШШИИШШШИШИШШИИШШП 


016-3 | 100000000 


and 


Шиш 


00000000002 1000000000000 


SELECT DATE ADD(NOW(), INTERVAL 21 DAY); 





ОбО0000000000 
Чі а шаш еш юне а د د دیک‎ юы + 
| DATE ADD(NOW(), INTERVAL 21 DAY) | 
аа PPP + 
| 2012-01-31 21:02:16 | 
+... + 


1 row in set (0.02 sec) 


ПООАТЕ 5О08О000000000 


l—————————— З + 
| DATE SUB(NOW(), INTERVAL 21 DAY) | 
а еа ан аве нане ваа а ве сае нана + 
| 2011-12-20 21:02:23 | 
+------ + + я + 


1 row in set (0.00 sec) 


00002. e- 30 lb p De dO ED PAY TIEIEIBA Y STEHEID AY SETTE] 
00000000 


ERROR 1064: You have an error in your SQL syntax near 'DAYS)' at line 1 


ООООО0О00000000000000АТЕ АБООДОАТЕ 5080000000 
ОО0О0000000000000000000000000000000000000000000000 


ОООО000000000000000000000000000000000000 


SELECT DATE ADD("2011-12-31", INTERVAL 1 DAY); 


ОО0000000000 


| row in set (0.00 sec) 


LILTLTLTLTLTLTLTLTLI 
SELECT DATE ADD("2011-12-31", INTERVAL 12 HOUR); 
ООО00000 
= + 
| DATE ADD("2011-12-31", INTERVAL 12 HOUR) | 
| 2011-12-91 12:00:00 MEM | 
Е ія UU ан + 


: row in set (9.00 sec) 


00000+0-00000000АТЕ АРО()00АТЕ SUBODBEDIBBULCUCC 
ПППП 


SELECT "2011-12-31" + INTERVAL 1 DAY; 


ОО0000000000 
| "2011-12-91" + INTERVAL 1 DAY | 
| 2012-01-01 В | 


| row in set (0.00 sec) 


16.11.7 ПИОООСООО 


Му5ОЦОМОУУОДОДОООООДО000000О00000000000000000000 
LEIDIBIOIDEIEIMy 5ОС0ООО000000000000000 


CURDATE()QCURRENT_DATE()Q000000000000YYYY-MM- 
2 БОДОДО000000000 


SELECT CURDATE(), CURRENT ОАТЕ(); 


ПО00000000000 
RN ———— —— нео + 
| CURDATE() | CURRENT DATE() | 
Pues ылы ee ee ai Жалаа ae d анЕ + 
| 2012-01-10 | 2012-01-10 
4 - - eee - - - - T---------------- + 


1 row in set (0.01 sec) 


ОДООСОВТІМЕОПСОВВЕМТ ТІМЕОДОДННОММ55ДОДООД 
0000000 


SELECT CURTIME(), CURRENT ТІМЕ(); 


ПО0000000000 
ванн diu НАЕ ры و‎ cu ais + 
| CURTIME() | CURRENT TIME() | 
jeune Rid OR E KADAR + 
| 09:14:26 | 09:14:26 | 
+----------- Е------------..... + 


1 row in set (0.00 sec) 


NOW(Q[]ISYSDATE(Q[JCURRENT TIMESTAMP()QQ00000000 
OYYYY-MM-DD НН:ММ:$$0000000000 


SELECT NOW(), SYSDATE(), CURRENT TIMESTAHP(); 


ОО0000000000 


d nee нн ear зала ыы u e ЕЕ ышы шы ны uae ыға + 
| МОМ) | SYSDATE () | CURRENT TIMESTAMP() | 


| 2012-01-10 15:23:52 | 2012-01-10 15:23:52 | 2012-01-10 15:23:52 | 


а Tena aaa ла ates, a ae eet dud варі ень атанын + 
1 row in set (0.00 sec) 


UNIX ТІМЕЗТАМРОДОДОУМІХОДООООДОООООД0ОД0000000000 
ПОМІХООДОООПУМІХОДООДСОЗОДУ МІХО000019/70010100000000 
ОО000000000 


SELECT UNIX TIMESTAMP (); 


ОДОб000000000000000 
a cannes | 
j 926867959 | 


1 row in set (0.00 и. 


ОООО000000009МІХОДОД 


SELECT UNIX TIMESTAMP ( 1973-12-30"); 


ОО0000000000 


1 row in set (0.00 sec) 


ПООООООООООРКОМ UNTX TIMEOLDITIBBIBBBIU МІХОДОДОДОООО 
ОО000000000000 


SELECT FROM UNIXTIME('1326247953') ; 


ППППППРАТЕ РОКМАТ(Ј000000000000000000000000000 
ПП 


mysql&gt; SELECT FROM UNIXTIME(UNIX TIMESTAMP(), "50 %M %Ү at 





ПООЕНОВОВИЙ 
———————————— НЕ + 
| FROM UNIXTIME('1326247953') | 
Jr шашын шии шнын шиа - 
| 2012-01-19 21:12:33 | 
T----------.-...-.-......--..-.--. t 


1 row in set (0.00 sec) 


П0000АТЕ_РОКМАТ()0000000000000000000000000000 


SELECT FROM UNIXTIME(UNIX TIMESTAMP(), "50 %M %Y at %hi%i:%s'); 


REBEEEEEEEREEEEEREENE 
=_=: + 
| FROM UNIXTIME(UNIX TIMESTAMP(), '%0 %М &Y at %һ:%1:%5') | 
———————— ек ана ë eee өс + 
| 10th January 2012 at 09:15:38 | 
Һ-------------............................................-. + 


1 row in set (0.00 sec) 


16.12 ||| 


ОООО0000005600000000000000000000000300000000 
ПИШШИШШИШИШШШШШШШШИШШШИШШЇҮИШҮШЇИПМУ^ОШЗ3ЦП[ 
ООО0О0000000000000000000 


ІМ5ЕЕТОООДОООООО0О0О000000000000000000000000000000 
ІМ5ЕЕТОООООДООО00000000000005ЕСЕС ТОДОООООО0О00000Ч00 
ООО00000000000000000000000000000000000000000000000 
ООООО0000000000000061МІОООО00000000000000000000000 
ОДОДОКОЄВ ВУДООООДООООООООО00ОО0О0000000000000000000 
ООООО0000000000000000000000000000000 


ООООО00000000000000000000000000000Д0УУНЕКЕОДОООД 
ООООО00000000000000000000000000000У/НЕКЕОСООООООООО 
ООООО00000000000000000000000000000000000000000)/01М1 
ОДОООО000000000000/)01МОДООООІМ МЕВ JOINIILEFT JOTNT | 
RIGHT )ОІМОДОМУ5ОЄПООООООООШ О ТМОДОДООООООДО0О000000 
ПООООООООЈОМ I 


ОРОАТЕПКЕРГАСЕ ПООООМУЗОПООООООДУРБАТЕДОДОО 
ООООО0О00000000000000000КЕРГАСЕПІМ5ЕВ ТОООООО0000000 
ООООО000000000000000000009РФАТЕСООООООООО000000000 
ОООО0000000000000000000 


DELE ТЕООПОООООООООООООООООО00О000000РЕСЕТЕООДО 
ОООДОО00000000000РЕСЕТЕПОООООООООООДУУНЕКЕРОДОДОДО 
ОД000егиерооО000000000000001МИГОРОДОООО00000000000000 
ОООО000000000000000000000000000000 


ОДООООО000000000000000МУЗО0ООО00О00ОМу5ОЄ0000000 
ООООООДО00О0О00О00000СОМСАТОПСОМСАТ WSOTIEENGTHOL 
ПОБОВОООВОВОООВОВОООБОВРАВОПЕРАРОПТЕМОПЕГАМОП 


ВАТМООООДООДООООООО0Д0-0ОСАТЕОДЬБОВУТВІМСОЦІЕРТОП 
ВІСНТОООДООДО000000000000000000000000000000000 

(| САБЕОПУСАБЕООКЕРЕАТООВЕРСАСЕООДОДОООООО0000000 
ОООМУуЗОРОООООО0О0О000000000000000000000000000000000 
ПППППИППППРАТЕ FORMATO) IILI IILI LI LIL IILI II LI! 
ОООООООООООООООрАТЕ_АРО()0рАТЕ 50В(Ј00000000000000 
ООО0000000000000000000000 


ОДООРАУОПУУЕЕКОДМОМТТНОДУЕАВОДОДООДОДОО00000000 
[[IWHERE[JORDER ВУООДОДООПО 


16.13 О&А 


ОбОООООО000000000000000000000 


АДООООДО0000000000640000000000000000000000000000 
ОДОО00000/0.0000000000000МУЗОЗООДООО0000000000000000 
ОООО00000000000000000000000 


С 


АООДОДОО0О0000000000000000000000000Опазеег name 
ПДАг5іпатеДбіа5іпатердддододо000 


SELECT UCASE(CONCAT WS(' ', firstname, lastname)) FROM master name; 


0000000 


| JOHN SMITH | 
| JANE SMITH | 
| JIMBO JONES | 
| ANDY SMITH | 
| CHRIS JONES | 
| ANNA BELL | 
| JIMMY CARR | 
| ALBERT SMITH | 
| JOHN DOE | 


9 rows in set (0.00 sec) 


000001 а5спатеродороо000000 


SELECT CONCAT WS(' ', firstname, UCASE(lastname)) FROM master name; 
00000000 


| СОМСАТ WS(' ', firstname, UCASE(lastname)) | 


| John SMITH 
| Jane SMITH 


| Jimbo JONES | 
| Andy SMITH | 
| Chris JONES | 
| Аппа BELL | 
| Jimmy САВЕ | 
| Albert SMITH | 
| John DOE | 


9 rows in set (0.00 sec) 


16.14 [ULL 


ООО0О00000000000000000000000000000000000000 


ӨШ 


1000566 78685 ПП00000000 
2000000000000000000ПарріеПреатПбапапарспетуп 
ЗОДО00000025000001МІИТОДОДО000000025000061МАТОД000 
АПОПООНКЕОПОВОПООООВОООВОО “John” “Joseph”? 
5П000000000&абіе1000000008000% 


0000050: 000000огаегѕ[іетѕ огдегеа 1000000000 
order Іа0О0огаегѕ$0000000000огдег name[]order date[][] 
items ordered[][][][]|]igtem description[][][] 


#0000 о Ц10000000000“ 9гаре"родод 
ОП" арріереаграпападгтаре" [O00 


erba applepearbananagrape" 0000500 
ПП 


ИЦ 


10МЕОІОМІМТ, ІМТПВІСІМТГ 
2ПЕМОМ ('apple', 'pear', ‘banana’, 'сһеггу') 
L 


SET ('apple', 'pear', 'banana', 'cherry')[| 


3[]LIMIT 0, 25[]LIMIT 25, 25П 

АПЦКЕ 'Jo96'[] 

5000000 а е1 а Пап 

o[]SELECT orders.order name, orders.order date, 
items ordered.item description FROM orders LEFT JOIN 
items ordered ON orders.order id = items ordered.id; 
7USELECT LOCATE('grape', 'applepearbananagrape"); 


a[]SELECT RIGHT("applepearbananagrape", 5); 


HOLI 


ОДООДО000000000000000001М5ЕВТО5ЕСЕСТОО 


1170 ULIMySQLII I IILI II 


00000000 


° ПОДООО000000Му5ОбЄ000000 
° ОООООО00000000МУу5ОФЕЛОДОСОГОП 


ОДОООО000005О0С:00000000000МУЗОЗОООО0ОО00000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
МУу5ОГОООО 


ООО0О0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000 


17.1 ПШ 


ООООО0000000000000000000000000000000000000000000 
ОООО000000З050:00000000000000000000000000000000000 
ООООО000000000000000000000000000000000000000000000 
ООО0О00000000000000000000 


ОО0ОО0000000000000000000000000000000000000000000 
ООООО000000000РАРОДОООЗОДОДО 


ПППїппоОВППППППППМуУ5ОГПППППППППППППМу5О1. 5.5.5000 ппорвроооооо | 
LL ]Ihttp: //dev. mysql. com/doc/refman/5.5/en/Innodb- default-se.htm!l ППППО x 
ПО00000000МУуІЅАМОПО00000000000 x 


ILIILIMySQLII I LILILILILILILILILILILIL IILI II II IL 


° COMMIT ----ПОООООООООО00О0О00000000000000000000 
0000000 

° ROLLBACK ----ОПОООООДОООО0О00000000000000000000 
ОО000000000 


ООООбОО000000ЗО00000000МуУ5ОС0О0000000000000000 
1000ВЕСІМЦООО0ОО00000 
200саюіе10000000000аюіе20 


зО00000абіе1П000000000КОЦ ВАСКОДДОООДОДОДОДОО 
0000000 


4000 Саре 1 Прп ПП сар! е21 


500 са оре 2 ПООООО00000000АОССВАСКОДОООДОДОДОДОО 
0000000 


6роДоДдорОбеабіет ррддддо00Овабіего 


/ПШПШПШШШЦЦПКабһ!езПЦШПШШПКОШ ВАСКППЦИПШШИШШИПШШИШШ 
00000000 


з00р0000000000абіезроДОоДсом міт ордророодро 0000000 
ULL] 


LIEIDBEHEIMy 5ОРДОООДОДО0000000000 
http://dev.mysql.com/doc/ 
refman/5.O/en/transactionalcommands.html ПМуУБОЦ UL] 


ОООО ОООО ОООО ООО ОООО 


17.1.2 ПОО 


ООООО000000000000000000000000000000000000000 
СВЕАТЕООООДОО 


CREATE TABLE store inventory ( 
id int not null primary key auto increment, 
item name varcharí(59), 
item price float(6,2), 
item qty int 
) ENGINE=InnoDB; 


CREATE TABLE store orders ( 
id int not null primary key auto increment, 
purchaser name уагсһаг(50), 
purchase date datetime 

J) ENGINE=InnoDB; 


CREATE TABLE store orders items ( 
id int not null primary key auto increment, 
order id int, 
inventory id int, 
item qty int 
) ENGINE-InnoDB; 


ППИПППвіоге inventory in III d II II 


D a аЕ Рос аЕ а Site анына Peete m + 
| id | item name | item price | item qty | 
К----4---44------- fesse eee eee %---------- + 
| 1 | Great Book | 19.99 | 19 | 
| 2 | Awesome CD | 9.99 | 20 | 
Eee te sasa ван а Picea чаги ца ен н нар + 


О000000000000000000000теає Воок$ПППАмезоте СОПОП 
00000 


І ПОООО00000000000000000000000000ВЕЗІМОДОДОДОООО 
ООО000000000000 


BEGIN; 


2050ге inventory ДП ОДОО0000000000 


UPDATE store inventory SET item qty = item qty - 2 WHERE id = 1; 
UPDATE store inventory SET item qty = item qty - 1 WHERE id = 2; 


ЭППвіоге огаеге ІППИІП 


INSERT INTO store orders (purchaser name, purchase date) 
VALUES ('John Smith', пом()); 


АОДОДООООО00О00КОССВАСКОДОООООООООООО00000000 


ROLLBACK; 


50000000000000000000010000000 
store orders іпеіетѕ00000000000000000000000000106500 
000 


INSERT INTO store orders items (order id, inventory id, item qty) 
VALUES (^T "3^4. '2'); 

INSERT INTO store orders items (order id, inventory id, item qty) 
VALUES ('1', '2', 117) 


J 


бОООООД00000000БОР2СВАСКООДОООООДОДО0000000 
store огаегб 00000000000 


ROLLBACK; 


ТОПОДООДО000000000000000000000000000К00 ВАСКОЦ 
ОО0000000000005іоге ord ers p ПДО00000000 
store orders _Ппе!їет$ЦЦПЦПППППППППП 


ROLLBACK; 


З ОДОООО00000000000000000000000000000000000 
СОММІТОПОООООООО0ОО00000000000000 


COMMIT; 


ОДОООО000000000000000Му5ОЄ0ОО0О0000ОРНРОДООООО 
ООООО00000000000000000РНРОДООООООДООО0О00О000000000000 
ООДОРНРОМУуЗО00000000000000002800000000 


ОО000002 80000000000000000000000000000000РНРеОООО 
00000000 


е mysqli autocommit() — 
http://www.php.net/mysgli autocommit 
е mysqli commit() —http://www.php.net/mysgli commit 
° туга! rollback() — 
http://www.php.net/mysgli rollback 


ПООООД00000000Му5ОЗ0Д000000000000000 
http://dev.mysql.com/doc/refman/5.5/en/sgl-syntax- 


transactions.htm! ППППИНИИНИНИОВООНИНОВОВООООООВОВОВОС 
ПП 


17.2 [JII 


ОО000000000000000000000%еюро0000050000000000 
ОО00000Меообо000000000000000000056100000000000000 
\Ммеопоо00000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000 


ОООО000000000000000000000000000000 


• 00008 ——0000000000005 9 ЄООДОДОДОС00000000000000 
ООО00000000000000 

• 0000 —=ОО000000000000000000000000%еюпо00000000 
ОООО0О00000000000000000000000000000000У/еБбр000 
ОДООО0О0000000000000000000000000000У/еБ000000000 
ОООО000000000000000000000000000000 


ООООО0000000000000000000000000000000000000000000 
ОО05О0:00000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
000000 


ООО000000000000000000 


CREATE TABLE testSP ( 
id int not null primary key auto increment, 
field name varchar(25), 
date added datetime 

) ENGINE=InnoDB; 


ОДОД00000000000 
+----+------------ +--------------------- + 
| id | field name | date added | 
deae oia ре ыан a ЖАЗЫ аса паб RR Di В ta US + 
| 1 | Value 1 | 2012-01-23 09:40:24 | 
| 2 | Value 2 | 2012-01-24 09:40:24 | 
| 3 | Value 3 | 2012-01-25 09:40:24 | 
| 4 | Value 4 | 2012-01-26 09:40:24 | 
| 5 | Value 5 | 2012-01-27 09:40:24 | 
| 6 | Value 6 | 2012-01-30 09:40:24 | 
| 7 | Value 7 | 2012-01-31 09:40:24 | 
| 8 | Value 8 | 2012-02-01 09:40:24 | 
| 9 | Value 9 | 2012-02-02 09:40:24 | 
| 10 | Value 10 | 2012-02-14 09:40:24 | 
+----+------------ +--------------------- + 


ОДООООО0000000000000000Му5ОЗ0ОО00О0000000000000 
ООО0000007/// ОДОО000000000000000 


DELIMITER // 


ОО000000000000000 


CREATE PROCEDURE procedure name () query // 


DEIEIBIDIDEIEDEIEIEICIDI EL IEe s CS PETETETHITIEIDIDEIEI DUI DIDI EID Ове 1 TT 
0000 


CREATE PROCEDURE spi () SELECT * FROM testSP WHERE date added BETWEEN 
DATE SUB(NOW(), INTERVAL 7 DAY) AND NOW() // 


ПОПИВОВОВОООСАЧЕПООООВОЕ 


CALL 5р1 () // 


ООООД005ЕРЕСТОООООООО0000000000 


Value 2 
Value 3 
Value 4 
Value 5 
Value 6 


2012-01-24 09:40:24 | 
2012-01-25 09:40:24 | 
2012-01-26 09:40:24 | 
2012-01-27 09:40:24 | 
2012-01-30 09:40:24 | 


002 ЗОООО000000ОРНРОООООЗОДОДОДООООД0ОО00000000000 


ОДООДОДО000000000000000000000000МузОї ООООО0О000000 
LLIhttp://dev.mysgal.com/doc/refman/5.5/en/stored- 
routines.html [] 


17.3 ||| 


ООО00000000000001ппорвроо00000Му5ОСТООООООО000 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО00000000000000000000 


17.4 Q&A 


ОПООМУу5ОЄПОООООО000000000 


АООООДООООООО00ОО00000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО0000000000000 


17.5 [II 


ОООО00000000000000000000000000000000000000 


ӨШ 


ІППІШІІМУІБАМПМУБОНППИПИПИПИПППТГППІ 
2В00003000000000200000000000000 


ЗОООО000000000000 


ИЦ 


1000і/ппоб вор држообрдбОбОП000 


2ПВОШ ВАСК 


ЗОООО00000000 


ӨШ 


О О О О О О 
ОООО0000000000000000000 


2 ПОООД0000000000000000000000000000000000000000 
ПП 


10180] ПШШРНРЦПМу5О || 


00000000 


° ПОООРНРОДОМУ5ОЇО 
° ПОДОРНРОДОДЗОДООО 


ОООДОО0ООРНРООООООДОМУуЗОСРОДООООО ОДОО0000000000 
ООДПОРНРОДОДООМу5ОСР0ООООО00000000000000000000000 
МуЗО СООДОООООО0Д0ОРНРОДООО 


18.1 МузоцМузош |) 


ООООО0ОРНРООООДОООООДОРАНРОДООДОМУу5ОЄ0О00000000 
mysql "ООД0О00000000000000000пузаї "00000000 


HUUUMysaQ 4.1.ЗПООО0О0000У0000Му SOLTETETETTEOID EIE PHP 
О0000000000000000000000туѕа!_ "00000 


ПООООООООООО0О00000000000туѕа!!_ "0000000000000000 
[|http://www.php.net/mysqili ПРНРООООООО 


18.2 ППРНРООМУ5О1 


ОООО0ОРНРОДОМу SQ С ООДОООУУевОДООЗОДОЗОДОДОДОДОП 
(Web БОООДОО000000Му SQ СООДООДО0О0Му 5О0Р0О000000000000 
ОООО0000000000000000020004000000000000000000000РНР 


ОМуз ОШ ПОП пете р ОООООО000000000000000000000000 
ОО000000000 


ОДОД0О000000000000000бе5с:0 8)0000Доецнз5егрро0000 
ѕотераѕѕ ПП ПП! 


ООО00б0000000000000000000000плузоїї, "ОбОООООО00000000000000000000 
ОДОДООО00 0000000 Ер им php. net/myssali ПРНРОДДДОО0ОД0О0000000000000000 | 


ПОООООООООРАРОООВОООООООРА POO0OO00000000000000000000000000000000000 
OOL x 


J00000000000000000000000000000000000000000000000000000000000000 
ОООД000000000000000000000000000000 | 


18.2.1 [OM 
ПООМу5О 00000000 


$mysqli = mysqli connect{"hostname", "username", "password", "database"); 


$mysqlit jj b p My SQ EETETEIETEICIET 


ОО00000000000000000 


$mysqli = mysqli connect{ "localhost", "joeuser", "somepass", "testDB"); 


000028 2000000000000000020000000000000000000000 
ООДООДО00000005000000000000000плузаї connect. еггог()00 
ОДОД0О000000000008000000000000000пмтуваїі, дес host info() 
ОО00000000 


000018.1 [JII 


1: <?php 

2: mysqli = new mysqli("localhost'", "joeuser", "5отера55", "testDB"); 
3: 

4: if (mysqli connect errno()) í 

Ds printf("Connect failed: %s\n", mysqli connect_error()); 

6: exit[); 

7: } else í 

М printf ("Host information: %s\n", mysqli get host info($mysqli)); 
9: } 

10: 7» 


ППИПИПИПтуваісоппесерһрППППИПИПУ/ео ПП ПП ПП 
УчерБ ПООДООДОООДО00000000000000000000 


Host information: localhost via TCP/IP 


ОО0000000000 


Host information: Localhost via UNIX socket 


ОДОООО0000000000000005000плузаїі, соппесі еггог()00000 
ОО000000000 


Connect failed: Access denied for user 'joeuser &G'localhost' (using password: 
YES) 


О000000000080000плуваї дес host іпѓо()000000000000 
ПП 


ООООО000000000000000000000000000000000000000000 


18.200900000000000 


000018.2 01000000000 





— — (O O YO 0] »0 N — 


— © 


«?php 
$mysqli = new mysqli{"localhost", "joeuser", "somepass", "testDB"); 
if (ту54д1і connect еггпо()) { 
printf ("Connect failed: %s\n", mysqli connect еггог()); 
exití); 
) else ( 


printf ("Host information: %s\n", mysqli get host info($mysqli)); 
mysqli close($mysqli); 
} 


2» 


О000050000000000туѕа!_сіоѕе()о50000000000050000000 


ООООО0000ОРНРООМу5О00О0000000000000000000000000000 
ООО000000000000 


18.2.2 ПИТИ 


ОДОО005О0С2000000000000000000ОРНРОДОМУЗОЗО00000000 


ПОПОРНРИПО ту а! query O0UUMySQLUUSQ LUOL 


ОДОД0О00000000000000000001 8.300000000000безітТабіе 


00000 


000018.3 ОДОДО000 


«?php 
$mysqli - mysqli connect("localhost", "joeuser", "somepass", "testDB"); 


if (mysqli connect еггпо()) í 
printf ("Connect failed: %s\n", mysqli connect еггог()); 


со N б 0 + G) N = 


exit(); 
} else { 

$sql = "CREATE TABLE testTable 
9: (id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
10: testField VARCHAR{75))"; 
11: $res = mysqli query($mysqli, $sql); 
12: 
13: if ($res === TRUE) í 
14: echo "Table testTable successfully created. "; 
151 ) else { 
16: printf ("Could not create table: %$\п", mysqli error($mysqgli)); 
ЊЕ } 
18: 
19: mysqli сіо5е(Фту5411); 
20: } 
21: 7> 


0080001000050:0000000055а10000000000000000000 
ЗОЗОООООО000О000000000000000000000000000000000 


музжа!_ачегуйпППП ООО true[jfalse[[ | |13[ LL 1if...else[ 000 
000000%геѕ000&гиеПоо0000000000000000000000000000 
МуБОЦ ПО Сез Таре ПООрЕ5СЕ!ВЕ test Та еп ПП 


ЧО 

Peas mansa РЕ ama aa а мани невин eee Ре рү c ——— M + 
| Field | Type | Null | Key | Default | Extra | 
рүе зз pss s бакшы ан Possess Poss Ша aaa se Жаша ee eee eee + 
| id | int(11) | | PRI | NULL | auto increment | 
| testField | магсћаг(75) | YES | | NULL | 
E He Grae ВВ таса 5 ЕВ LET ae I + 


ПППППИППППИПИППИПРНРИМУБОНЦТПИПИПИИПИППГІ 


ПППППөгез ИНО гие p i Ep i EET] my sg hi. еггогоП 
0000 


18.2.3 [j| III 


О00000000Оплузаї, еггогООООООО000000000РНР die oriidii] 
О0000000000000000000000000000туѕа!!_еггог()0000000000 
000000 


ОДОб000000000000бе5і Те терддоООДООО00О0000000000000 
ОД000000000УМеБооодророб0000000 


Could not create table: Table 'testtable' already exists 


ПООДООДООД00Д00000000000000000000ОРНРеОДОДОДОДООО 
18.3 ППМу5ОЦ 


ООО0000000000000000пмузаїі, query ОО00000001 600000 
ООО5О:00000ІМ5ЕВ ТООРРАТЕПРЕСЕ ТЕПООООООООО000000000 
ОООО000000000000000000005ЕСЕСТОДООДОООООО0000000000 
ООООО00000000000000000000000000 


18.3.1 || 5ОГ || 


О000018.З0000000050:100000000000000000000000000 
О0000%еБр00000\ебооо00000000000000000000000000000 


ООООО0Д000000000000000000000000000000000000000000000 
ООДО0000000000502000000 


ОООО000000000000000000000059 2:000000000059060000 
ООО0О00000000000000000000000000000000 


ППППИХКСРЫГЦПІППІИ Че Bobby Tables niibibii ISQ 00000 
ООО0О0000000000000000000000000000000000000000000000 
ППППППППППИПИПГІ Don't forget Little Bobby Таріе5!'"ПЛОГП 
http://xkcd.com/327/ 1000000 


О00000000000000ч5ег500000000000паптерророо0000000 
ПППППИПППУу/еот ІІ 


SELECT * FROM users 
WHERE name = '".$ POST[ username from Тогт ]." ; 


ППивегпате from РогиАДОДОДООПО 
' or '1'='1 
ПООДО000000000 


SELECT * FROM users 
WHERE name = ' ' or '1'='1'; 


ОООО0000000000000001 100000 


ОДОДО000000000000РНР О00005ОЦООООООООООООООООО 
[]http://www.php.net/manual/en/security.database.sg|l- 
injection.php О0000000000000005000000000000000000000 
ОО0О000000000000000000000000000000000000000000000о 


ОООО0000000000000000000000000000000000000000000000 
ОО000000000000 


ОООООООО00000000000МУу5ОСОРНРОДОООООДОРРО(РИАР 
Data Објесёѕ)О00000000000000000000№0р:// www. php. net/ 


manual /en/book.pdo.php ОП00000000000000000000000000 
ПООО С 2: www.php.net/manual/en/pdo.prepared- 
statements.php [] 


18.3.2 (|ІРНРІТ! 


ООООО0000000000000000001М5ЕВТОД000000 18.4000 


000018.4 ООДО00000 


1: <?php 

2: S$mysqli = mysqli connect("localhost", "joeuser", "somepass", "testDB"); 
d 

4: if (mysqli connect errno()) í 

Bi printf("Connect failed: %s\n", mysqli connect еггог()); 

6: exit(); 

7: } else { 

5: $sql = "INSERT INTO testTable (testField) VALUES ('some value')"; 
9: $res = mysqli query($mysqli, $sql); 

19: 

It: if ($res === TRUE) { 

12: echo "A record has been inserted."; 

13: ) else ( 

14: printf ("Could not insert record: %s\n", mysqli error($mysqli)); 
194 

16: 

17; mysqli close($mysqli); 

18: } 

19: ?> 


00000 1 8. ЗПОООООООО00000000000000000018.3000000000 
00000005000000008000055а100000000000122000140000000 


ОООДО0000000000000000Му5ОС:0ОО000000000000000000000 


О000000Опмуваїі п5егі рирОООООООПУУеБОДОДОООООООО0О 
test Таре ПОДД0ДО0О0О00000000000000000000000000000502000 
О0000000тувзаї, query  ОООООО0О00О0000000000000000000000 
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<!DOCTYPE html> 

<html> 

<head> 

<title>Record Insertion Form</title> 

</head> 

<body> 

«form action="insert.php" method="POST "> 

<p><label for="testfield">Text to Add:</label><br/> 

<input type="text" id="testfield" name="testfield" size="30" /></р> 
: <button type="submit" name-"submit" value="insert">Insert Record«/button» 
: </form> 
: </body> 
: </html> 


со - O л + Wh ~ 


© 


as‏ ك 
O № — S-‏ 


О00000000їп5егі Тогт ntm tibi Web ДО ОДОДОДОДОП 
00000000 18. 600 тег. рирОДОДООО0000000000005 POS T 
| testfield 00000 о 000000000 0 


000018.6 ПППППИПИПИПИПГ 


«?php 
$mysqli = mysqli connect("localhost", "joeuser", "somepass", "testDB"); 


if (mysqli connect еггпо()) { 
printf("Connect failed: %s\n", mysqli connect еггог()); 


eo N Фф €)» соо — 


exití(); 
| else í 

$clean text = mysqli real escape string($mysqli, $ POST[ testfield']); 
9; $sql = "INSERT INTO testTable (testField) 
10: VALUES ('".$clean text."')"; 
11: $res = mysqli query($mysqli, $sql); 
la: 
13: if ($res === TRUE) { 
14: echo "A record has been inserted."; 
15: y else í 
16: printf ("Could not insert record: %s\n", mysqli error($mysqli)); 
17: 
18: 
19: mysqli close($mysqli); 
20: ) 
21: 2?» 


О00000000028.400000000000008500000000000000000501 
0000000100000000000%сіеап веехерродододовоощюодог 
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[=] Record Insertion Form 


€ > а (QOnttp//localhost/18/insert form.html З, 


Text to Add: 
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[Text to АЧАД ДОО000000018-2000 





Record Insertion Form 


€ Э а (9nhttp;//localhost/18/insert form.html a, 
Text to Add: 
Little Bobby Tables 





Insert Record 
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[5] localhost/16/insert.php 


c С! ©) http:;//localhost/18/insert.php 
А record has been inserted. 
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ОДООООО00000000Му 5О0Є0О000000000000 


SELECT * FROM testTable; 


000000004 
| id | testield о | 


| 1 | some value | 
| 2 | Little Bobby Tables | 
C" —— I t 
2 rows іп set (0.00 sec) 
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ОДОД0О0000000000000000000000000000птузаіі, num. гому5() 
00000000028.700012000 


о — O, O + 0 N = 


000018.7 DB 


«?php 
$mysqli = mysqli connect("localhost", "joeuser", "somepass", "testDB"); 


if (mysqli connect errno()) ( 
printf("Connect failed: %s\n", mysqli connect еггог()); 
exití(); 
| else 1 
$sql = "SELECT * FROM testTable"; 
$res = mysqli query($mysqli, $sql); 


if ($res) í 
$number of rows = mysqli num rows($res); 
printf("Result set has за rows.\n", $number of rows); 
) else 
printf("Could not retrieve records: %s\n", mysqli еггог(%туза11)); 


mysqli free result($res); 
mysqli close($mysqli); 
: } 


· ?> 
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ООООО000000000000000000000000000000000000000 


Result set has 4 rows. 


012000пузаїї num гом'600000000005 respi d ib ID p IL 


П0000000$питрег ої гомѕП00001300000000000000000000 
ОО00000000000000 


ОО000000000000000000000180000туѕаіі free result 000000 | 
mysqli_close()0000000000mysqli_free_result() 0 00000000000000000000000000 
000 | 


ООООД000000000000000040000000000000000000000000 
ОООО00000000000000000000000000000000 


О0000000Ом'плтеродрордрдороооророороворороророворовобо 
О00000000пмтузаїі fete. агаубодоо0000 


$newArray = mysqli fetch array(S$result set); 
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000018.8 ОДОДОДОДО000000 


1: <?php 

2: %тувд11 = mysqli connect("localhost", "joeuser", "somepass", "testDB"); 
3: 

4: if (mysqli connect errno()) { 

5: printf("Connect failed: %s\n", mysqli connect еггог()); 

6: exit(); 

7: } else í 

8: $sql - "SELECT * FROM testTable"; 

9: $res = mysqli_query($mysqli, 5541); 

10: 

11: if ($res) í 

12: while ($newArray = mysqli fetch аггау(%гев, MYSQLI ASSOC)) í 
13: $id = $newArray['id']; 

14: $testField = $newArray[ 'testField' |; 

151 echo "The ID is ".$id." and the text is: ".$testField."«br/»"; 
16: } 

17: | else í 

18: printf ("Could not retrieve records: %s\n", mysqli error($mysqli)); 
19: } 

20: 

21: mysqli free result($res); 

22: mysqli close($mysqli); 

23: } 


LLL Es ее. php m Web bp lp m m i ID E We bp mi IH 
ОДОД0000000000без5іТевіерддо00000000000018-00000000 
02 20001 500МУБПеДОДООО 





[=] lacalhast/18/select.php 
€ СҰ ©) http;//localhost/18/select.php ~ 
The ID 5 1 and the text 1s: some value 
The ID 15 2 and the text 1s: Little Bobby Tables 
The ID 5 5 and the text 5: Here's more text! 
Ihe ID 5 б and the text 15: I really like cheese. 
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18.3.4 РНРИПОПМУЗОЦИП 


ПОРАНРООМу5ОВІДО0010000000000МУу5О 00000000000 
ООО0О0000000000000000000000000000000000000000000000 
ПППИППППППРНРЦИИПМУ 5ОЄ0ОО0О00О00О00000000000000000000 
ОДООПЕЄр ://ww w. php. net/mysqli ПРНРОДОМУу5ОГІДОГ 


18.4 || 


ПОРНРЮМУуЗОРДОДОООДОО0О0О00УУеворобрОООДООО0ОРНРОП 
ОООООО0000000000000Му 50ЄПОООД00000000000000 
туѕа!!_ачегу()О00000000000000000000000000005000 


ОДОРНРЮДОМУуЗОС ОДОДПОМУЗОЗПОООО0000000000000000 
П0туѕа!!_ачегу()0000000500)000000000005ЕЕЕСТОО00000 
туѕа!ї_ num _гомѕ()0000000000000000000000000000000000 
ППППтува! Тессһ аггау()О00000000000000000 


18.5 Q&A 


О0000000000000000музаї ЯПтувай "0000 


АПООРНРОДООООООООООООООО0ООО00000МУ5ЗОСОО00000000 
ПООМУЗОЕ 4.1.30000000пузаї *00000000000000000000000 
ООО0О000000000000000000000000000000000000000 


18.6 ППТ 


ООО0000000000000000000000000000000000000000 


ӨШ 


І0ООДОРНРОМУу5ОСО0ООО00000000000000000 
2 ПОРНРОПООДОМУу 5ОЄ0О000000 


ЗОДОРНРОДООООООО00О0000000000 


ИЦ 


1[]mysgli соппесє)СО000000МУЅОЦОООООООООООООООО 
2[]mysgli еггог(УПДООДОМу5ОЄ00000 


ЗПпузаїї num _гомѕ()00000000000000 


ЦИН 


100000} ТМЕБДОРНРОДОООООООООО0ОООООО0О00О0000000000 
ОО00000000000 


2 ПОООО00000000ОРНРОДООООООООО0О0О0О0О00000000000 
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00000000 
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00000000 
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ОО000000000 


• ПОДПООООД/СО0000000 
° ПОДО0О00000000 
° (ПП 


ОООООО00000000000000000000000000000000000РНРП 
MySQ СООООООО000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000 


ООООО0О0000000000000000000000ОРНРОМУ5ОС00000000 
ООООО0000000000000000000000000000000000000000000000 
ООСВОУОПОДОО00000000000000000000000000000 


ООООО0000000000000000000000000000000000000000000 
ОООО000000000000000000000000000 
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ООООО0000000000000000000000000000000000000000000 
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• ОДООООООЕплаіорр000 
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ПОО000000000000 
19.1.1 [subscribers] 


Пвиовсгіреге  ДОООДОДООДО0ООДО00000Е6 тан 00006086 
ОГОООООО0О0000000000000000000м/пегероо0Д001900000000 
ЕттанО00000000000000000000050:100000000 


CREATE TABLE subscribers ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
email VARCHAR (150) UNIQUE NOT NULL 

J; 


ПППЕгаа ПП ППоМЮФЕГППППППИПИГАППППППИГИПГІ 
Ета! о ОО000Еплайоррордордодоіаро 0 


ООООД00О00Му SQETTETETEBEIEIBCID DIEI DEIE CIC EIL D ES CT 
DESCRIBE ОООООООД0О000000000000 


mysql> DESC subscribers; 


еннен da menm nite seme Р +----- рана нан нова ння юнак я аю + 
| Field | Туре | Null | Key | Default | Extra | 
%------- %-------------- %------ %----- %--------- %-------------.-. + 
| id | int(11) | NO | PRI | NULL | auto increment | 
| email | уагсһаг(150) | NO | UNI | NULL | 

%------- %-------------- %------ %----- %--------- %--------------.-. + 


2 rows in set (0.00 sec) 


ООО000000000000000000000000000000 
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1: <?php 

2: // function to connect to database 

3: function doDB() 1 

4: global $mysqli; 

2 

6: /[connect to server and select database 

7: $mysqli = mysqli connect("localhost'", "joeuser", 
В: "somepass", "testDB"); 

9: 

10: //if connection fails, stop script execution 
11: if (mysqli connect errno()) í 

12: printf("Connect failed: %s\n", mysqli connect еггог()); 
13: exit(); 

14: } 

15: } 


16: // function to check email address 
17: function emailChecker($email) í 


18: global $mysqli, $safe email, $check res; 

19: 

20: / {check that email is not already іп list 

21: $safe email = mysqli real escape string($mysqli, $email); 
22: $check sql - "SELECT id FROM SUBSCRIBERS 

23: WHERE email = '".$safe email."'"; 

24: $check res = mysqli query($mysqli, $check sql) 

25: ог die(mysqli error($mysqli)); 

26: } 

el [= 
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00000000000Омападе.  рпРрОДООПООООООООДОДОД00000000 
119.210тападе.рһро0000000000000000000000000000000 
ОДООДОО00000000000000000000000000000000Н TM ECTCTETEICIETT | 
ПП 


000019.2 ООпападе рирОДО00 


о чо UO PE G@ N = 


© 


<?php 
include 'сһ19 include.php'; 
//determine if they need to see the form or not 
if (1% POST) ( 
//they need to see the form, so create form block 
$display block = «««END OF BLOCK 
«form method="POST" action="$ SERVER[PHP SELF]"» 


«p»«label for="email">Your E-Mail Address:</label><br/> 
«input type-'email" id="email" name="email" 
size="40" maxlength-"' 150" /></p> 


<fieldset> 

<legend>Action:</legend><br/> 

<input type="radio" id="action sub" name="action" 
value-"sub" checked /> 

«label for="action_sub">subscribe</label><br/> 

«input type="radio" id="action unsub" name-"action" 
Value="unsub" {> 

«label for-"action unsub">unsubscribe</label> 

</fieldset> 


«button type="submit" name="Submit" value="submit">Submit</button> 
</form> 
END OF BLOCK; 
ү else if (($ POST) && ($ POST['action'] == 'sub")) { 
//trying to subscribe; validate email address 
if ($ POST['email'] == "") ( 
header("Location: manage.php"); 
exit; 
) else ( 
//соппесћ to database 
doDB(); 


//check that email is in list 
emailChecker($ POST['email']); 


//get number of results and do action 
if (mysqli num rows{$check res) < 1) í 
/[free result 
mysqli free result($check res); 


//add record 
$add sql - "INSERT INTO subscribers (email) 
VALUES('".$safe ета11."')"; 
$add res = mysqli query($mysqli, Зада sql) 
or die(mysqli error($mysqli)); 
$display block = "<p>Thanks for signing up!</p>"; 


//close connection to MySQL 
ту5411 close($mysqli); 
) else ( 
//print failure message 
$display block = "<p>You're already subscribed!</p>"; 


55: } 


56: ) 

57: } else if (($ POST) && (5 POST['action'] == "unsub")) í 
58: //trying to unsubscribe; validate email address 
59: if ($ POST['email'] == "") ( 

60: header("Location: manage.php"); 

61: exit; 

62: ) else ( 

63: //connect to database 

64: doDB(); 

65: 

66: //спеск that email is in list 

67: emailChecker($ POST['email']); 

68: 

69: //get number of results апа do action 

70: if (mysqli num rows(S$check res) < 1) í 

ті» //free result 

78: mysqli free гези1т(бсћеск_ res); 

73: 

74: //print failure message 

то; $display block = "«p»Couldn't find your address!</p> 
76: <p>No action was taken.</p>"; 

77: ) else ( 

78: //get value of ID from result 

79: while ($row = mysqli fetch аггау(%сһеск res)) í 
80: $id - $row['id']; 

81: ) 

82 

83: //unsubscribe the address 

84: $del sql = "DELETE FROM subscribers 

85: WHERE id = ".$id; 

86: $del res = mysqli query($mysqli, $4е1 541) 
87: or die(mysqli error($mysqli)); 
88: $display block = "«p»You're unsubscribed!</p>"; 
89: } 

90: mysqli close($mysqli); 

91: } 

92: } 

93: ?> 

94: <!DOCTYPE html» 

95: <html> 

96: <head> 


97: <title>Subscribe/Unsubscribe to a Mailing List</title> 
98: </head> 

99: <body> 

199: «hi»Subscribe/Unsubscribe to a Mailing List</h1> 

101: <?php echo "$display_block"; ?> 

102: </body> 

103: </html> 
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Subscribe/Unsubscribe to a Mailing List 


"Your Email Address: 
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ОДОО0000000000000 


0000000000033000д2080000000с119 іпсінде.рһрП [ИП 
00000000000000003600000000000000Оетаїйспескег 00000 
ОО00000000005 POST. Геплаї 10000000000000000 19. 100210 
102500000етанісһескег()00000000000000000000000000 
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ПООО0000000000000 


О0000003900005спеск respi inibi ПП9сһеск respi ici 
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ООО00000000000000000000440004800000000000000000000 
О000054000000000001?....етверод0000001010)Д00н7МмО000010 
0000000 


005 РО5ТДП000ігией005 РО5ТГасніоп""ДОДО00" unsub "ОО 
ПО00000000000000000000000000000000000Ета!о00000000 
0590006110000000000000000000000 


П000000000640009аорв()0000000000000067000 
етаі!сһескег()О00000000000%сһеск_ге$0007000000000000 
О000000Е тан ооДооброорооб00000001 00000000000000000 


ОООО000000000/75000/7600000000000000200000000000 
О0000008400088000000000000017...етер00001010000 
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e Subscribe/Unsubscribe to г 


= Q ©) hitp://localhost/19/manage.php Ki A ~ 


Subscribe/Unsubscribe to a Mailing List 


Thanks for signing up! 


[19-2 0000 





© Subscribe/Unsubscribe to а 


€ C О nttp//localhost/19/manage.php [€] м з 


Subscribe/Unsubscribe to a Mailing List 


You're already subscribed! 





[19-3 [nut 
(С) Subscribe/Unsubscribe to а 
5 С ©) http;//localhost/19/manage.php йок А 


Subscribe/Unsubscribe to a Mailing List 


Youre unsubscribed! 


[19-4 0000 


© Subscribe/Unsubscribe to г 
= C ©) http;//localhost/19/manage.php Комо ~ 


Subscribe/Unsubscribe to a Mailing List 


Couldn't find your address! 


No action was taken. 
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ОбООО000000000000000000000000000000000000000000 
subscribersOO00000000000000000000sendmymail.phpooooo 
19.3000000 


000019.3 01000000000 


ON Oop Ó n = 


со 


«?php 
include 'ch19 include.php'; 
if (!$ POST) ( 
//haven't seen the form, so display it 
$display block = «««END OF BLOCK 
<form method="POST" action="$ SERVER[PHP SELF] "> 


«p»«label for="subject">Subject:</label><br/> 


<input type="text" id-"subject" name-"subject" size="4@" /></р> 


<p><label for="message">Mail Body:</label><br/> 
<textarea id="message" name="message" со15="50" 
rows='1@'></textarea></p> 


«button type="submit" name="submit" value="submit">Submit</button> 


</form> 
ЕМО OF BLOCK; 


) else if (5 POST) 
//want to send form, so check for required fields 


if (($ POST['subject'] == "") || ($ POST['message'] == "")) í 


} 


header("Location: sendmymail.php"); 
exit; 


/{/connect to database 
doDB(); 


if (mysqli connect errno()) { 


//1f connection fails, stop script execution 
printf ("Connect failed: %s\n", mysqli connect еггог()); 
exit(); 


} else { 


} 


: Ж» 
: «IDOCTYPE html» 


//otherwise, get emails from subscribers list 
$sql = "SELECT email FROM subscribers"; 
$result = mysqli query($mysqli, 5541) 

or die(mysqli error($mysqli)); 


//create a From: mailheader 
$mailheaders = "From: Your Mailing List 
<you@yourdomain.com>"; 
//loop through results and send mail 
while ($row = mysqli fetch array($result)) { 
set time 11т1%(0); 
$email - $row['email']; 
mail("Semail", stripslashes($ POST['subject']), 
stripslashes($ POST['message']), $mailheaders); 
$display block .- "newsletter sent to: ".$email."<br/>"; 
) 
mysqli free result ($result) ; 
mysqli close($mysqli); 


23: **IILIIH LA^ 

54: «head» 

55: <title>Sending a Newsletter</title> 
56: </head> 

57: <body> 

58: <hi>Send a Newsletter</hi> 

59: <?php echo $display block; ?> 

60: </body> 

61: </html> 
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e Sending a Newsletter 


€ > а (Olocalhost/19/sendmymail.php 
Send a Newsletter 
Subject 


Mail Body: 
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set time Ига ОППИПППППППОПГ по limit. "ОДОДООД000000000 
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C Sending a Newsletter 
= Q | © http;//localhost/19/sendmymail.php 


Send a Newsletter 


newsletter sent to: jane(@doe.com 
newsletter sent to: jcmeloniz gmail.com 
newsletter sent to: john smith com 


[19-7 0100000 


This а Test Mail © тех x 


sm Print all 


Your Mailing List you@yourdomain.com 5:27 РМ (2 minutes ago) +. 
to те [=] 


| like cheese. Do you? 
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2 00000 тува ПОООООООДОДООО0О00О00О000000000000000 
ОООО0000000000000000000000000000000 


3[]et time limit(O)[] 


ӨШ 
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id, date added, date modified, f name, | пате 


id, master id, date added, date modified, address, 
address | n H E 
City, state, zipcode, type 


id, master id, date added, date modified, tel number, 
Telephone : š H = E 
ype 


= id, master id, date added, date modified, 
x 
fax number, type 
Id, master id, date added, date modified, email, type 
id, master id, date added, date modified, note 
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(ППШБОЦЦПІППтавеег пате 


CREATE TABLE master пате 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
date added DATETIME, 
date modified DATETIME, 
f name VARCHAR (75), 
1 name VARCHAR (75) 


000000000000000000 m a ster. nam e Drm аааге $011 
ППППаПППаағе added[]date поаїнпеалдрдордододооо 
master id] 


master id[][][[|master патеррдріадодододоюдоооо 
master Іа00000000000000000000000000000000&урероо00 
ООООООДО0000000З000000000000З30000поплебмуогкОоїпет ET] 
ОООООДО000000000000000014600000000000000000000000000 
ПО000000ааагеѕѕ$[сіїуПѕёаѓеП21ірсоаеПо0000000 


CREATE TABLE address ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
master id INT NOT NULL, 
date added DATETIME, 
date modified DATETIME, 
address VARCHAR (255), 
city VARCHAR (38), 
state CHAR (2), 
zipcode VARCHAR (10), 
type ENUM ('home', 'work', 'other') 


сеіерһћопе[ғахПетано0000000000000056110000 


CREATE TABLE telephone ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
master id INT NOT NULL, 
date added DATETIME, 
date modified DATETIME, 
tel number VARCHAR (25), 
type ENUM ('home', 'work', 'other') 
}; 
CREATE TABLE fax ( 
id INT NOT NULL PRIMARY KEY AUTO ІМСВЕМЕМТ, 
master id INT NOT NULL, 
date added DATETIME, 
date modified DATETIME, 
fax number VARCHAR (25), 
type ENUM ('home', 'work', 'other') 


); 
CREATE TABLE email ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
master id INT NOT NULL, 
date added DATETIME, 
date modified DATETIME, 
email VARCHAR (159), 
type ENUM ('home', 'work', 'other') 


personal по*е Д00000000000Оптазіег rd bibi d I! 
LEnotes[ 05000000 


CREATE TABLE personal notes ( 
id int NOT NULL PRIMARY KEY AUTO INCREMENT, 
master id INT NOT NULL UNIQUE, 
date added DATETIME, 
date modified DATETIME, 
note TEXT 
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000020.1 01000000000 


1: <?php 

2: function doDB() { 

3: global $mysqli; 

4: 

а: /[connect to server and select database; you may need it 
6: $mysqli = mysqli connect("localhost", "joeuser", 

7: "somepass", "testDB"); 

8: 

9: [111 connection fails, stop script execution 

10: if (mysqli connect еггпо()) í 

11: printf ("Connect failed: %s\n", mysqli connect error()); 
la: exit(); 

13: } 

14: } 

15: T> 
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000020.2 ПШПШ 


«IDOCTYPE html» 

«html» 

<head> 

<title>My Address Book</title> 
</head> 

<body> 

<hi>My Address Book</h1> 


со -ч oat AN = 


со 


<p><strong>Management</strong></p> 

19: <ul> 

11: <li><a href="addentry.php">Add an Entry</a></1li> 
12: <li><a href="delentry.php">Delete ап Entry</a></1li> 
13: </ul> 

15: <p><strong>Viewing</strong></p> 

16: <ul> 

17: <li><a href="selentry.php">Select a Несога</а></11> 
18: </ul> 

19: </body> 

20: </html> 


020-1000000020.20000000000р00000000000000007Ааа 
an Entry" 0 


(С) My Address Book 


< с о http;//localhost/20/mymenu html hl M ~ 
Му Address Book 


Management 


е Add an Entry 
* Delete an Entry 


Viewing 


e Select a Record 
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0000020 зорододруробрОааддепігу. РЕРОООООООСООООД0О0О 
ООДО00000000000040008900000000000000000000091201018 7 
Дррозорое9р00рро000Н тмерророр0000005аїзріау, біоск ПО 
ПП 


000020.3 ППадаептгу.рир DU 


<?рһр 
include 'ch20 include.php'; 


if (1$ POST) ( 


ON Doha N — 


со 


/fhaven't seen the form, so show it 

$display block = «««END OF TEXT 

<form method="post" action-"$ SERVER[PHP ЗЕЕ] "> 

<fieldset> 

<legend>First/Last Names:</legend><br/> 

<input type="text" name-"f name" 5126-30" 
maxlength="75" required="required" /> 

<input type="text" name-"l name" 5і7е-"30" 
maxlength="75" required="required" /> 

</fieldset> 


«p»«label for="address">Street Address:</label><br/> 
<input type="text" id="address" name="address" 
size-"30" {></p> 


<fieldset> 

<legend>City/State/Zip:</legend><br/> 

<input type="text" name="city" size-'30" maxlength="50" /> 
<input type="text" name-"state" size="5" maxlength="2" /> 
<input type="text" name="Zipcode" size="1@" maxlength="10" /> 
</fieldset> 


<fieldset> 

<legend>Address Type:</legend><br/> 

<input type="radio" id="add type h" name-"add type" 
value-"home" checked /» 
«label for-"add type һ'>һоте</1абе1> 

«input type="radio" id="add type w" name="add type" 
Value="work" /» 
«label for="add type w'>work</label> 

«input type="radio" id="add type o" name="add type" 
value-"other" /> 
«label Тог="ада_ type o'»other«/label» 

</fieldset> 


<fieldset> 
<legend>Telephone Number:</legend><br/> 
<input type="text" name="tel number" size="30" maxlength="25" 
<input type="radio" id="tel type h" name="tel type" 
value=" home" checked /» 
«label for= tel type _h">home</label> 
«input type="radio" id="tel type м" name-"tel type" 
Value="work'" /» 
«label for="tel type w">work</label> 
«input type="radio" id-"tel type о" name="tel type" 
value= ' other" /» 
<label for="tel type o">other</label> 
</fieldset> 


{> 


54; <fieldset> 


gg <legend>Fax Number:«/legend»«br/» 

58: <input type="text" пате="Тах number" size="30" maxlength="25" /> 
57: «input type="radio" id-"fax type h" пате-"Тах type" 

58: Value="home" checked /> 

59: «label for-"fax type h"-home«/label- 

60: <input type="radio" 19="Тах type м" name="Tax type" 

61: value-" work" /» 

62: <label Тог- Тах type w">work</label> 

63: «input type="radio’ id-"fax type o" name-"fax type" 

64: value-"other" /> 

65: «label Ғог=" Ғах type о">оїһег</1абе1> 

66: </fieldset> 

Br: 

68: <fieldset> 

69: <legend>Email Address:</legend><br/> 

19: «input type="email" name-"email" size-'30" maxlength-"150" f> 
71: <input type="radio" id="email type h" name-"email type" 
КЕ: value- home checked /> 

73: «label Тог= email type П'»Потех/Іабе!» 

74: «input type="radio" id-"email type м" name-"email type" 
75: Value="work" /» 

76: <label for="email type w">work</label> 

77: «input type-"radio" id-"email type o" name-"email type" 
78: Value="other" /> 

79: «label for="email type o"»other«/label» 

89: «/fieldset» 

81: 

82: <p><label for="note">Personal Note:</label><br/> 

83: «textarea id-"note" name-"note" со15= "35" 

84; rows="3"></textarea></p> 

85: 

86: «button type="submit" name-"submit" 

87: Value="send">Add Entry</button> 

88: </form> 


89: END OF TEXT; 
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>. ^ m | = | =) (б 
j Add an Entry | 
< С | © http://localhost/20/addentry.php кі м 3, | 
Add an Entry 

First/Last Names: 
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90: 
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) else if (5 POST) { 


//time to add to tables, so check for required fields 


if (($ POST['f name'] == "") || {$ POST['1 name'] == "")) { 
header("Location: addentry.php"); 
exit; 

} 

/fconnect to database 

8008 ( ) ; 


//create clean versions of input strings 

Ssafe f name = mysqli real escape string($mysqli, 
$ POST['f name']); 

$safe 1 name = mysqli real escape string($mysqli, 
$ POST['1l name']); 

$safe address = mysqli real escape string(Smysqli, 
$ POST['address']); 

Ssafe city = mysqli real escape stringí$mysqli, 
$ POST['city' |); 

$safe state = mysqgli real escape string($mysqli, 
$ POST['state']); 

$safe zipcode = mysqli real escape string(Smysqli, 
$ POST['zipcode']); 

$safe tel number = mysqli real escape string($mysqli, 
$ POST['tel number']); 

$safe fax number = mysqli real escape string($mysqli, 
$ POST['fax number']); 

$safe email = mysqli real escape string($mysqli, 
$ POST['email']); 

$safe note = mysqli real escape string(S$mysqli, 
$ POST['note']); 


/fadd to master name table 


$add master 541 = "INSERT INTO master name (date added, 
date modified, f name, 1 name) VALUES 
(now(), now(), '".$safe f name."', '".$safe 1 name."')"; 


Фада master res = mysqli query($mysqli, $add master 541) 
or die(mysqli error($mysqli)); 


¿iget master id for use with other tables 
$master id = тузаја insert id($mysqli); 


if (($ POST['address']) || ($ POST['city']) || 

($ POST['state']) || (5 POST['zipcode'])) ( 

/ ¿something relevant, so add to address table 

Фаса address 541 = "INSERT INTO address (master id, 
date added, date modified, address, city, state, 
zipcode, type) VALUES 
('".S$master id."', now(}, now(}, 
'" $safe address."', '".$safe city."', 
'".$safe state."' , '".$safe zipcode."' , 
'".$ POST['add type']." ')"; 

фаса address res = mysqli query($mysqli, Фада address sql) 
or die(mysali error($mysqli)); 


144: 
145: 
146: 
147: 
148: 
149: 
152: 
151: 
152: 
153: 
154: 


} 


if ($ POST['tel number']) { 

/isomething relevant, so add to telephone table 

$add tel sql - "INSERT INTO telephone (master id, date added, 
date modified, tel number, type) VALUES 
("".бтавтег id."', now(), now(}, 
'" ФзаТе tel number."', '".$ POST['tel їуре'|."')"; 

Фаса tel res = mysqli query($mysqli, $add tel sql) 
or dieímysali errorí($mysqli)); 


) 


155: 


156: if (5 POST['fax number']) { 

197: f; {something relevant, so add to fax table 

158: $add fax 541 = "INSERT INTO fax (master id, date added, 
159: date modified, fax number, type) VALUES 

168: ('".$master id."', now(), now(), '".$safe fax number."', 
161: :",5 POST['fax type']." ')"; 

162: Фада fax res = mysqli_query(Smysqli, $add fax 541) 

163: or die(mysqli еггог(%тув611)); 

164: } 

165: if (5 POST['email']) ( 

166: //something relevant, so add to email table 

167: $add email sql - "INSERT INTO email (master id, date added, 
168: date modified, email, type) VALUES 

169: ('".$master id." ', now(), now(), '".$safe email."', 
170: '".$ POST['email type']."')"; 

171: Фада email res = mysqli query($mysqli, $add email sql) 
172: ог die(mysqli error($mysqli)); 

173: ) 

174: 

175; if (5 POST['note']) 1 

176: //something relevant, so add to notes table 

1773 $add notes sql = "INSERT INTO personal notes (master id, 
178: date added, date modified, note) VALUES 

179: ('".$master id."', now(), now(), 

189: '".$safe note."')"; 

181: Фада notes res = mysqli query($mysqli, $add notes sql) 
182: or die(mysali error($mysqli)); 

183: ) 

184: mysqli close($mysqli); 

185: $display block = "«p»Your entry has been added. Would you 
186: like to «a href=\"addentry.php\">add another</a>?</p>"; 
187: } 

188: 7?» 

189: <!DOCTYPE html> 

198: <head> 


191: <title>Add an Entry</title> 
192: </head> 

193: <body> 

194: <h1>Add an Entry</h1> 

195: <?php echo $display_block; ?> 
196: </body> 

197: </html> 
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C Add an Entry 
< С | © http;//localhost/20/addentry.php кі к ~ 


Add an Entry 


Your entry has been added. Would vou like to add another? 
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000020.4 дододр0000005еїепігу рРарООО 


O N Oc + G N = 


со 


«?php 


include сһ20 include.php' ; 


doDB(); 


if (15 POST) í 
/fhaven't seen the selection form, so show it 
$display block = "<hi>Select an Entry</hl>"; 


/ ¿get parts of records 
$get list sql = "SELECT id, 


CONCAT WS(', ', 1 name, f name) AS display name 
FROM master name ORDER BY 1 name, f name"; 


$get list res = mysqli query($mysqli, $get list sql) 


or die(mysqli error($mysqli)); 


if (mysqli num rows($get list res) < 1) í 


//no records 
$display block .= "<p><em>Sorry, no records to select!</em></p>"; 


у else І 


) 


/[has records, so get results and print in a form 

$display block .- " 

«form method=\"post\" action=\"".$ SERVER[ 'PHP_SELF']."\"> 
<p><label for=\"sel id\">Select а Record:</label><br/> 
<select id="sel_ 191" name=\"sel_id\" required=\"required\'> 
«option уа1ие=\"\">-- Select One --</option=" ; 


while ($recs = mysqli fetch аггау(5деї list res)) í 
$id = $recs['id']; 
$display name = stripslashes($recs['display_name']); 
$display block .= 


"<option value=\"".$id."\">".$display name."</option>"; 


} 


$display block .- " 

</select> 

«button type=\"submit\" name-i"submit|" 
Value=\"view\">View Selected Entry\"></button> 

</form>"; 


//tree result 
mysqli free result($get list res); 
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) else if (5 POST) í 
{icheck for required fields 


if ($ POST['sel id'] == "") í 
header("Location: selentry.php"); 
exit; 

} 


|| сгеафте safe version of ID 
$safe id = mysqli real escape string($mysqli, $ POST['sel id']);52: 


{дет master info 

$get master sql = "SELECT concat ws(' ',f name,l name) as display name 
FROM master name WHERE id = '".$safe id." "; 

$get master res = mysqli query(S$mysqli, $get master 541) 
or die(mysqgli error($mysqli)); 


while ($name info = mysqli fetch array($get master res)) í 
$display пате = stripslashes($name info['display name']); 
) 


$display block = "<hi>Showing Record for ".$display пате. "</11>"; 


/[free result 
mysqli free result($get master res); 


дет all addresses 
$get addresses sql - "SELECT address, city, state, zipcode, type FROM 
address WHERE master id = '".$safe id." "j 
$get addresses res = mysqli query($mysqgli, $get addresses sgl) 
ог die(mysqli error($mysqli)); 


if (mysqli num rows(S$get addresses res) > 0) (í 


р огох „= '"<p><strong>Addresses:</strong><br/> 
<] >"; 


while ($add info = mysqli fetch аггау(5деї addresses res)) í 
address = stripslashes($add_info[ address 1); 
$city = stripslashes($add info['city']); 
$state = stripslashes($add info['state']); 
$Zipcode = stripslashes($add info[ 'zipcode' |); 
$address type = $add info['type']; 


$display_block .= "<li>$address $city $state $zipcode 
($address_type)</li>"; 
) 
$display block .- "</ul>"; 


} 
ііТгее result 
mysqli free result($get addresses res); 
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182: 
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197: 
148: 
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131 
132: 
133: 
134: 
135: 
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141: 
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143: 
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146: 
147: 


$get tel sql - "SELECT 


92: ујка 


tel number, type FROM telephone WHERE 


master іа = '".$safe_id."'"; 
$get tel res = mysqli query($mysaqali, $get tel 541) 
or die(mysqgli error($mysqli)); 


if (mysqli num rows($get tel res) > 0) 4 


$display block .- " 
«ці»" - 


while ($tel info = 


<p><strong>Telephone: </strong><br/> 


mysqli fetch array($get tel res)) 1 


$tel number = stripslashes($tel info['tel number']); 
$tel type = $tel info[ type']; 


$display block 
) 
$display block .= ' 
) 


/{Тгее result 
mysqli free result($get 


líget all fax 
$get fax 591 = "SELECT 


master. 


„= "«li»$tel number ($tel type)</li>"; 


</ul> ES 


tel res); 


fax number, type FROM fax WHERE 
id = '".S$safe id."'"; 


$get fax res = mysali query($mysqli, $get fax 541) 
ог die(mysqli error($mysqli)); 


if (mysqli num rows($get fax res) > Q) í 


$display block .= `" 
«ці»"; 


while (%Ғах info = 
$fax number - 
Фтах type = $fa 


$display block 
) 
$display block .- 
} 
/ffree result 
mysqli free result ($get 


//get all email 
$get email sql = "SELEC 
maste 
$get email res = mysqli 
or die 
if (mysqli num rows($ge 
$display block .- 
<ul>"; 


while ($email_info 
$ета11 = strip 
Фетаі1 type = 


$display block 


<p><strong>Fax:</strong><br/> 


mysqli fetch array($get fax res)) í 
stripslashes($fax info[ fax number']); 
x info['type']; 

.= "«li»$fax number ($fax Туре)</11>"; 


"</ul>"; 


fax res); 


T email, type FROM email WHERE 
г id = '".$safe id."'"; 


_query(Smysqli, $get email 541) 


(mysqli еггог(Фтуза11)); 
t email res) > 0) í 
“<p><strong>Email:</strong><br /> 


= mysqli fetch array(Sget email ге5)) í 
slashes(S$email info['email']); 
$email info['type' 1; 


„= “<li>$email ($email type)«/li»"; 


148: 
149: 
150: 
151: 
152: 
153: 
154: 
155: 
156: 
157: 
158: 
159: 
160: 
161: 
162: 
163: 
164: 
165: 
166: 
167: 
168: 


169: 
179: 
171: 
172: 
173: 
174: 
HIS: 
176: 
177: 
178: 
179: 
180: 
181: 
182: 
183: 
184: 


} 
$display block ,= "«/ці»"; 
} 
//free result 
mysqli free result($get email res); 


//get personal note 
$get notes sql = "SELECT note FROM personal notes WHERE 
master id = '".$safe 14."""; 
$get notes res = mysqli query($mysqli, $get notes sql) 
ог die(mysqli error($mysqli)); 


if (mysqli num rows($get notes res) == 1) í 
while ($note info = mysqli fetch array($get notes res)) í 
$note = nl2br(stripslashes($note info[ note'])); 


} 
$display block .- "<p><strong>Personal Notes:</strong><br/> 
fnote</p>"; 

} 

//free result 

mysqli free result($get notes res); 


ОО00000000000000000Ч900020.4000000000 


000020.4 додод0р0000005еїепігу php ET TL 


$display block .= "<br/> 
«р style=\ "text-align :center\ "> 
«a href=\"".$_SERVER[ 'PHP_SELF']."\">select another</a></p>"; 
} 
//close connection to MySQL 
mysqli close($mysqli); 
2> 
<!DOCTYPE html» 
<html> 
<head> 
<title>My Records</title> 
</head> 
<body> 
<?php echo $display block; ?> 
</body> 
</html> 


001. 720007... .етверрДОДОООРАРОДОДОДОДООІ1 690001 71000 


ОО0000000000000000 176 ОДООО000000000Офаїзріау біоскПД 


ППППИИНТМИППИП 


00020-4000000000000000000000020-500000000000000 
00000 


Ех 
(9 My Records 
€ Q | © http;//localhast/20/selentry.php К м З 


Showing Кесога Тог Jane Doe 
Addresses: 

е 123 Main Street Washington DC 20011 (home) 
Telephone: 

e 555.555.1212 (home) 
Fax: 

* 555-555-1313 (work) 
Email: 

* jane@doe.com (home) 


Personal Notes: 
Jane is pretty cool. 


020-5 000000 


ООО0О0000000000000000000000000000000000000000000 
ULL] 


ППТ ICE e ma ПОВОВЕ тан 0006 
ООООО0000000000000000000000000000000000000000 


20.6  ППООООООП 


ОО00000000000000000000000000000000000020.400042 
рррородородроаєвіепігу ph рО0000000002400038007Міем/" ПД 
“Феее” mr] 


ураезрробавіепігу РЕРОООО00000000020.5000 


000020.5 П00000000000аеепїгу.рһро00 


431 
44: 
45: 
46: 
47! 
48: 
49: 
50: 
51: 


52: 
gd. 


54: 
55; 
56: 
57: 
58; 
59: 
6@: 
61: 
62: 
63: 
64: 
65: 
66: 
67: 
68: 
69: 
70: 
71: 
ТЕ: 
Fg 
74: 
ri. 
76: 
77: 
78: 
79: 
80: 
81: 
82: 
83: 
84: 
85: 
86: 
87: 
88: 
89: 
90: 
91: 
92: 
93: 
94: 
95: 
OB! 


) else if (5 POST) ( 
//check for required fields 


if ($ POST['sel id'] == "") í 
header("Location: delentry.php"); 
exit; 

} 


//create safe version of ID 
$safe id = mysqli real escape string($mysgli, $ POST['sel id']); 


/[issue queries 
$del master sql 


"DELETE FROM master name WHERE 

id = '".$safe id."'"; 

$del master res = mysqli query($mysqli, $del master 541) 
or die(mysqli error($mysqli)); 


"DELETE FROM address WHERE 

id = '".$safe іа. "'"; 

$del address res = mysqli query($mysqli, $del address sql) 
or die(mysqli error($mysqli)); 


$del address 541 


$del tel 5421 = "DELETE FROM telephone WHERE id = '".$safe id."'"; 
$del tel res = mysqli query($mysqli, $del tel sql) 
or die(mysqli error($mysqli)); 


$del fax sql = "DELETE FROM fax WHERE id = '".$safe id."'"; 
$del fax res mysqli query($mysqli, $del fax 541) 
or die(mysqli error($mysqli)); 


$del email sql = "DELETE FROM email WHERE id = '".$safe id."'"; 
$del email res = mysgli query($mysgli, $del email sql) 
ог die(mysgli error($mysgli)); 


$del note sql = "DELETE FROM personal notes WHERE 
id = '".$safe і4."""; 
$del note res = mysqli query($mysqli, $del note 541) 
or die(mysqli error($mysqli)); 


mysqli close ($mysqli) ; 


$display block = "<hl>Record(s) Deleted</h1> 
<p>Would you like to 
«a href=\"".$ SERVER[ PHP SELF']."V"»delete another«/a»?«/p»"; 
} 
2» 
«IDOCTYPE html» 
<html> 
<head> 
<title>My Records</title> 
</head> 
<body> 
<?php echo $display block; ?> 
</body> 
</html> 


ПП45ЦПШПШШЦШЦШПШП$_РО5Т Гзе! іа 1000005еїепіту. рирД) 
ОДООДОО00000000000000000000000000000000000005100000 
00000000054000/90000000000000000000000000008301085 
О000000005фаїзріау біоскДОДОДООО00000НТ7М000000020-6П00П 
ОО0000000000 


[e| Ë! ass 
C My Records 
= Q О hitp://localhost/20/delentry.php КІ м А 
Kecord(s) Deleted 


Would vou Ше to delete another? 
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ООООО0000000000000000000000000000000000000000000 
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ОООО0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
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0000020.4Д5еїепігрирд0000018500018600000 
$display block .- "<р style=\"text-align:center\"> 


«a href=\"addentry.php?master_id=".$ POST['sel id']."i"»add лпто</а> ... 
«а href=\"".$ SERVER[ PHP SELF']."\">select another</a></p>"; 


000000Оаадаепіту риродороОдоб000000005 СЕТ 
['master Іа' 00000000000 


О0000000000000000000020.300аааепїгу.рпро00000000 
ОО0000000000 


00000000000Оадаепіту рир 010901 


<?php 
include ‘'ch2@ include.php'; 
doDB( ) ; 


if ((15 POST) || (5 GET['master id'] !- "")) ( 
/fhaven't seen the form, so show it 
$display block - " 
«form method=\"post\" action=\"".$ SERVER['PHP SELF']."i"»"; 
if (isset($ GET['master id'])) í 


іісгеаће safe version of ID 
$safe id = mysqli real escape string($mysqli, $ GET[ master id']); 


¿iget first, last names for display/tests validity 
$get names sql = "SELECT concat ws(' ', f name, 1 name) AS display name 
FROM master name WHERE id = '".$safe id."'"; 
$get names res = mysqli query($mysqli, $get names 541) 
ог die(mysqli error($mysqli)); 


if (mysqli пит rows($get names res) == 1) 4 
while ($name info = mysqli fetch array($get names res)) 4 
$display name = stripslashes($name info['display name']); 


) 
) 
) 
if (isset($display пате)) í 
$display block .= "<p>Adding information for 
<strong>$display_name</strong>:</p>"; 
} else { 
$display block .= <<<END OF TEXT 
<fieldset> 


<legend>First/Last Names:</legend><br/> 
<input type="text" name-"f name" size="30" 
maxlength-"75" required="required" /> 
<input type="text" name-"l name" size="30" 
maxlength="75" required-"required" /» 
</fileldset> 
ЕМО OF TEXT; 
} 
$display block .- «««END OF TEXT 


<p><label for="address">Street А44ге55:</1аһе1><рг/> 


ОО0О0000000000000000000000000000000000000000000 
ООООО00000000000000000000000000001900000000 


0000000 аддепіту. риродоодроробо0 


«button type="submit" name-"submit" мајџе="5епа">АдДа Entrys/button- 


ОбО0Д000000000 
ЕМО ОР ТЕХТ; 
if (5 GET) ( 
$display block .= "<input type=\"hidden\" name=\"master 104" 
ма1ие=\ пп : $ GET[ "master id І ] | " \ ШП = 


} 


$display block .= «««END OF TEXT 


О0000000плазіег та ПП 


00000000910002 ЗОДОДООООООО00000000000000 
$master таб ОДОДО00000000000 


те to add to tables, so check for required fields 
if ((($ POST['f name'] == "") || {$ POST['1 name'] == "")) && 
(!isset($ POST['master id']))) 4 

header("Location: addentry.php"); 

exit; 


} 


{{соппесї to database 
doDB(); 


Іісгеате clean versions of input strings 

$safe f name = mysqli real escape string($mysqli, 
$ POST['f name']); 

$safe 1 name = mysqli real escape string(Smysali, 
$ POST['1 name']); 

$safe address = mysqli real escape stringí($mysqli, 
$ POST[ 'address 1); 

$safe city = mysqli real escape string($mysqli, 
$ POST['city']); 

$safe state = mysqli real escape string($mysqli, 
$ POST['state 1); 

$safe zipcode = mysqli real escape stringí($mysqli, 
$ POST['zipcode |); 

$safe tel number = mysqli real escape string($mysqli, 
$ POST[' tel number']); 

$safe fax number = mysqli real escape string(S$mysqli, 
$ POST['fax number']); 

$safe email = mysqli real escape string{$mysqli, 
$ POST['email']); 

$safe note = mysqli real escape string($mysqli, 
$ POST['note']); 


if (1% POST['master id']) { 
¿iadd to master name table 
$add master sql - "INSERT INTO master name (date added, date modified, 
f name, 1 name) VALUES (пом(), now(}, 
'" $safe f name."', '".$safe 1 name."')"; 
padd master res = mysqli query($mysqli, $add master sql) 
ог die(mysqli error($mysqli)); 


//get master id for use with other tables 

$master id = mysqli insert id($mysqli); 
| else 4 

$master id = mysqli real escape string($mysqli, $ POST['master id']); 
| 


ОООО000000000000000000000000000000000000000 
$ POST ['master 1а']ПООООЦ 


ООДОДОООДО000000000000000000000005 РО5Т 
[master 1Ф)00000000000000плазсег патедо000 


0000000000П0Орегвопаї notes rris QEDTEITIDEDIINSERTTET 
ОРРАТЕЦ00поѓеѕП00000 


$add notes sql = "UPDATE personal notes set note = '".$safe поте. "', 
date modified = now() WHERE master id = '".$master id." "; 


О0000000000020.60П0 


000020.6 [lJaddentry.php[][] 


о ч O CO! + wh — 


26: 


37: 


39: 


«?php 
include ‘ch2@ include.php' ; 
doDB{ ); 


if ((!$ POST) || ($ GET['master id'] 1- "")) í 
/ ¿haven't seen the form, so show it 
$display block = " 
«form method=\"post\" actionzV"".$ SERVER['PHP SELF']."\">"; 
if (isset($ GET['master id'])) ( 
//create safe version of ID 


$safe id = mysqli real escape string($mysqli, $ GET['master id']); 


//get first, last names for display/tests validity 
$get names sql = "SELECT concat ws(' ', f name, 1 name) AS 
display name 
FROM master name WHERE id = '".$safe 10."'"; 
$get names res = mysqli query($mysqli, $get names sql) 
or die(mysqli error($mysqli)); 


if (mysqli num rows($get names res) == 1) { 
while ($name info = mysqli fetch array($get names ге5)) í 


$display name = stripslashes($name info['display name']); 


} 
) 
) 
if (isset($display name)) { 
$display block .- "<p>Adding information for 
«strong»$display name</strong>:</p>"; 
) else І 
$display block .- «««END OF TEXT <fieldset> 


<legend>First/Last Names:</legend><br/> 
<input type="text" name-"f пате" size="30" 
maxlength="75" required-"required" /> 
<input type="text" name-"l name" size="30" 
maxlength="75" required="required" /> 
</Tieldset> 
ЕМО ОР ТЕХТ; 
} 
$display block .= «««END OF TEXT 
«p»«label for-"address'»Street Address:«/label»«br/» 
«input type="text" id="address" name="address" 
size-"30" /></р> 
I eDieuiBtata/zipre/iegandxaBr» 
<input type="text" name-"city" size-" 30" maxlength="50" /> 
«input type="text" name-'state" size- 5" maxlength-2 2" /> 
«input type="text" name-"zipcode" size-"10" maxlength="10" 
«/fieldset- 


«fieldset- 
«]egend-Address Туре: </1едепа><6г/> 
«input type-'radio" id="add type h" name-"add type" 


54: 
55: 
56: 
57: 
58: 
БӨ: 
60: 
61: 
62: 
63: 
54: 
65: 
66: 
67: 
68: 
69: 
ҒӘ: 
Ti: 
72: 
та: 
74: 
ToS: 
тб: 
ҮТ: 
78: 
139: 
80: 
81: 
82: 
83: 
84: 
85: 
86: 
87: 
88: 
89: 
92: 
91: 
92: 
93: 
94: 
95: 
96: 
97: 
98: 
99: 
1049: 
181: 


value=" home" checked /> 
«label Tor-"add type h"»-home«s/label- 
«input type="radio" id-"add type м” пате= "асас type" 
Value="work" /> 
«label for-"add type м">могКк</1абе]> 
«input type="radio" id- add type o" name-"adda type" 
value-"other" /> 
«label for-"add type o"-other«/label- 
«/fieldset- 


<fieldset> 


<legend>Telephone Number:</legend><br/> 
<input type="text" name="tel number" size-"30" maxlength="25" 
«input type="radio" id- tel type h" name-"tel type" 
value-"home" checked /> 
«label forz"tel type h"»-homecs/label- 
«input type="radio" id="tel type w" name-"tel type" 
Value="work" /> 
«label Tor-"tel type w"-works/label- 
«input type="radio" id-"tel type o" name-"tel type" 
Value="other" /> 
«Label for="tel type _o">other</label> 
</Fieldset> 


«fieldset» 
<legend>Fax Number:</ legend><br/> 
<input type="text" name-"fax number" size-"30" maxlength="25" 
<input type="radio" id-"fax type h" name-"fax type" 
value-"home" checked /> 
«label for="fax_type_h">home</label> 
«input type-"radio" id-"fax type у" name-"fax type" 
value-"work" /> 
«label for-"fax type w">work</label> 
«input type-"radio" id-"fax type o" name-"fax type" 
value-"other" /> 
<label Тог-"Тах type o"-other«/label- 
«/Тіе1азеї» 


<fieldset> 
<legend>Email Address:</legend><br/> 
<input type="email" name="email" size="3¢" maxlength="150" /> 
<input type="radio" id-"email type h" name="email type" 
Value="home" checked /> 
<label for-"email type _h">home</label> 
<input type="radio" id-"email type м" name-'email type" 
value-"work" /» 
«label for="email type w">work</label> 


{> 


{> 


1@2: «input type="radio" id-"email type о" name="email type" 


183: value-"other" /> 

104: «label for="email_ type_o">other</label> 
185: </fieldset> 

106: 

197: <p><label for-"note"-Personal Note:</label=<br/> 
198: «textarea id="note" name="note" cols="35" 

199: rows="3"></textarea></p> 

110: END OF TEXT; 

111: if ($ GET) { 

112: $display block .- "<input type=\"hidden\" name=\"master_id\" 
113: value-i"".$ GET['master 1а']."7">"; 

114: 

115: $display block .- «««END OF TEXT 

116: «button type="submit" name=" submit " 

117: Value="send">Add Entry</button> 

118: </Torm> 


119: END OF TEXT; 
120: } else if ($ POST) { 


121: //time to add to tables, so check for required fields 

122: if ((($ POST['f name'] == "") || (З РОЗТ['1 name'] == "")) && 

123: (!isset($ POST['master 14'1))) 1 

124: header( "Location: addentry.php"); 

125: exit; 

126: } 

127: 

128: ¿Į ¿connect to database 

129: doDB(); 

130: //create clean versions of input strings 

131: $safe f пате = mysqli real escape string($mysqli, 

132: $ POST['f name']); 

133: $safe 1 name = mysqli real escape string($mysqli, 

134: $ POST['l name']); 

135: $safe address = mysqli real escape string(Smysqli, 

136: $ POST[ 'address']}; 

137: $safe city = mysqli real escape string{$mysqli, 

136: $ POST['city']); 

139: $safe state = mysqgli real escape string($mysqli, 

140: $ POST['state']); 

141: $safe_zipcode = mysqli real escape string(S$mysqli, 

142: $ POST['zipcode']); 

143: $safe tel number = mysqli real escape stringí($mysqli, 

144: $ POST['tel number']); 

145: $safe fax number = mysqli real escape string($mysqli, 

146: $ POST['fax number']); 

147: $safe email = mysqli real escape string($mysqli, 

148: $ POST[ 'email']); 

149: $safe note = mysqli real escape string($mysqli, 

150: $ POST['note']); 

151: 

152: if (1% POST['master id']) { 

153: /Ғаса to master name table 

154: $add master 541 = "INSERT INTO master name (дате added, 
date modified, 

155: f name, 1 name) VALUES (now(), now(), 

156: '".$<аТе f name."', '".$safe 1 пате."')"; 


157: Фада master res = mysqli query($mysqli, Фасо master 541) 


158: 
159: 
160: 
161: 
162: 
163: 


164: 
165: 
156: 
167: 
168: 
169: 
170: 
171: 
172: 
173: 
174: 
175; 
176: 
177: 
178: 
178; 
188: 
181: 
182: 
183: 
184: 
185: 
186: 
187: 
188: 
189: 
194: 
191: 
192: 
193: 
194: 
195: 
196: 
197: 
198: 
199; 


2040: 
201: 
202: 
203: 
204: 
205: 
206: 
207: 
208: 
209: 
218: 
211: 
212: 


ог die(mysqli error($mysqli)); 


//get master id for use with other tables 
$master id = mysqli insert id($mysqli); 


} else { 
$master id = mysqli real escape stringí($mysqli, 
$ POST[' master 141); 
) 
if (($ POST['address']) || (8 POST['city']) || 
($ POST['state']) || ($ POST['zipcode'])) í 
//something relevant, so add to address table 
зада address sql = "INSERT INTO address (master id, 


date added, date modified, address, city, state, 
zipcode, type) VALUES 
(7. $master id."', now(), now(), 
.$safe | address. 5 зеи 
.$safe state. , ".$safe zipcode."' 
.$ POST['add type']."')j" 
badd address res = mysqli яйеге шел, $add address 541) 
or die(mysqli errorí($mysqli)); 
) 


if (5 POST['tel number']) { 
//something relevant, so add to telephone table 


$add tel sql = "INSERT INTO telephone (master id, date added, 
date modified, tei number, type) VALUES 
('".Smaster id."', new()s nowí), 
".$safe tel number."', '",$ POST['tel type']."')"; 


$add tel res = mysqli query($mysoli, Фада tel sql) 
ог die(mysqli error($mysqli)); 
} 


if ($ POST['fax number']) { 
/fsomething relevant, so add to fax table 
зада fax 541 = "INSERT INTO fax (master id, date added, 
date modified, fax number, type) VALUES 
('".$master id."', пом); пом(), '".$safe fax number."', 
'"".$ POST['Tax type']."')" 
Фада fax res = mysqli . query ($mysqli, $add fax sql) 
or die(mysqli error($mysqli)); 
} 
if ($ POST['email']) + 
//something relevant, so add to email table 


зада email sql = "INSERT INTO email (master id, date added, 
date modified, email, type) VALUES 
('".Smaster_id."', now(), now(), '".$safe email."', 


'".$ POST['email type']."')"; 
Фада email res = mysqli query(S$mysqli, $add email 541) 
or die(mysqli errorí($mysqli)); 


} 


if (5 POST['note']) ( 
//something relevant, so add to notes table 
зада notes sql = "UPDATE personal notes set note = 
'".Ssafe note."', date modified = пом) 


213: 
214; 
215: 
216: 
217: 
218: 
219: 
220: 
221: 
222; 
223: 
224: 
225: 
226: 
227: 
228: 


WHERE master id = '".$master id."'"; 

} 

mysqli close($mysqli); 

$display block = "<p>Your entry has been added. Would you 

like to <a href=\"addentry.php\">add another</a>?</p>"; 

) 
2> 
<!DOCTYPE html» 
«head» 
<title>Add an Entry</title> 
</head> 
<body> 
<hi>Add ап Entry</hi> 


<?php echo $display block; ?> 
</body> 
</html> 
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0000000 


i ©) Add an Entry 











| < С http://localhost/20/addentry2.php?master id-3 


Add an Entry 
Adding information for John Smith: 


Street Address: 


— City/State/Zip: 






































—Address Туре:- 


—Fax Number: 


Per sonal Note: 
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Showing Кесога for John Smith 


Addresses: 


* 546 Apple Lane Sometown CA 95128 (home) 
е 999 Bluebird Lane San Jose СА 95128 (work) 


Telephone: 

* 408-555-1212 (work) 
Fax: 

* 555-555-1313 (work) 
Email: 


e john@smith com (home) 
e john(gjohnsjob.com (work) 
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ООООО000000000000000000000000000000000000000000 
ООО000000000000000000000000000000000000000000000000 
ОООО0000000000000000000 


ООООО0000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ООО000000000000000000 


ОООО0000000000000000000богит tepices[irerum. postsr] 


CREATE TABLE forum topics ( 
topic id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
topic title VARCHAR (150), 
topic, create time DATETIME, 
topic owner VARCHAR (150) 


); 
CREATE TABLE forum posts ( 
post id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
topic, id INT NOT NULL, 
post text TEXT, 
post create time DATETIME, 
post owner VARCHAR (150) 


ОООО0000000000000000000000000000000000000000000 


21.2 ПОООО00000000 


ОООО0000000000000000000000000000000000000000000 
ООДО000000000000000Ч90000022 12000000000000000 


000021.1 01000000000 


«?php 
function doDB() í 
global $mysqli; 


/[connect to server and select database; you may need it 


ON O O + Ó N ~ 


$mysqli = mysqli connect("localhost", "joeuser", 
"somepass", "testDB"); 

9: //1f connection fails, stop script execution 
10: if (mysqli connect еггпо()) 4 
113 printf ("Connect failed: %s\n", mysqli connect еггог()); 
12: ехії(); 
13: } 
14: } 
15: 7> 
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«IDOCTYPE html» 

«html» 

<head> 

<title>Add a Topic</title> 

</head> 

<body> 

<hi>Add a Topic</h1> 

<form method="post" action="do addtopic.php"> 


: <p><label for-"topic омпег">Үоиг Email Address:</label><br/> 
: «input type="email" id-"topic owner" name="topic_owner" size="4Q" 


maxlength="150" гедилгед=" гедилгед" /></р> 


: <p><label for-"topic _title">Topic Title:</label><br/> 
: «input type="text" id="topic title" name-"topic title" size-"40" 


maxlength="150" required="required" /></p> 


: <p><label for="post text">Post Text:</label><br/> 
: <textarea id="post_text" name="post_ text" rows="8" 


cols="4@" ></textarea></p> 


: «button type-"submit" name-"submit" value-"submit"»Add Topic</button> 


: </form> 
: </роду> 
: </html> 


ОО0000000000021-2000000000З00000000000000000000 


О00000000000000000000021.2)0000Падаоріс петіД0000000 
О00%Уебро000000000000000000 
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Add a Topic 


Your Email Address: 
Topic Title: 


Post Text 
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$ POST['topic ІШе 11% POST['topic owner'] topic Іар 
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$ POST ['topic owner' ІППІПППрове id[]post create ште[ 
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00000002. .З00000000000000000 
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«?php 
include 'ch21 include.php'; 
doDB(); 


//check for required fields from the form 

if ((!$ POST['topic owner']) || (1% POST['topic title']) || 
(1% POST['post text'])) { 
header{ "Location: addtopic.html"); 
exit; 

} 


/Ғсгеате safe values for input into the database 


: $clean topic owner = mysqli real escape string($mysqli, 


$ POST['topic owner']); 


: $clean topic title = mysqli real escape string($mysqli, 


$ POST['topic title']); 


: $clean post text = mysqli real escape string($mysqli, 


$ POST['post text']); 


//create and issue the first query 


: $add topic sql = "INSERT INTO forum topics 
(topic title, topic create time, topic owner) 


VALUES ('".$clean topic title ."', now(), 
"".$$clean topic owner."')"; 


: Фада topic res = mysqli query($mysqli, $add topic sql) 


or die(mysqli error($mysqli)); 


//get the id of the last query 


: $topic id = mysgli insert id($mysqli); 


//create and issue the second query 


: $add post 541 = "INSERT INTO forum posts 
(topic id, post text, post create time, post owner) 
VALUES ('".$topic id."', '".$clean post text."', 


now(), '".$clean topic омпег."')"; 


: Фада post res = mysqli query($mysqli, $add post sql) 


or die(mysqli error($mysqli)); 
/[close connection to MySQL 


: mysqli close($mysqli); 


//create nice message for user 


: $display block = "<p>The <strong>".$ POST["topic title"]."«/strong» 


topic has been created.«/p»"; 


: 2> 

: <!DOCTYPE html» 

: «html» 

: «head» 

: <title>New Topic Added</title> 
: </head> 

: <body> 

: «hi»New Topic Added</h1> 


E. ons ` puispridy ULIUUM; 27 

56: </html> 
ПӘПППӘПППППИППИПИППИПИППППИПППППИППППОЙППТОПППГ 
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forum жорісеППППаЦ ПППогит posts topic Іа00000 


ОЗ ЗОДОЗ9ООДОД0000000000000000000000000000000000 
О00000000000#огит роз5к50004400045000000000000000000 
ОООО0000000000000Н FM 


00000000090 аааборіс.рирДоОДОДООЗОООО0000000000 
учеб)000000000000021-100000000000000000Мемм Topic 
Аааеа 01021-2021-300000000 
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Add a Горїс 
Your Ета! Address: 


Topic Title: 
How did you get started with technology? 


I'm interested in knowing how people got = 
Started in technology -- did you tinker Г 
with household electronics? Did you lear 
about it in school? Did your parents buy|= 
you a computer and tell you to have at і: 


When did you start hacking on things? 
4 ІШ 
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New Торіс Added 


The How did you get started with technology? topic has been created. 
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«?php 
include 'ch21 include.php'; 
doDBí(); 


//gather the topics 

$get topics sql = "SELECT topic id, topic title, 
DATE FORMAT(topic create time, %0 %е %Y at %r'} AS 
fmt topic create time, topic owner FROM forum topics 
ORDER BY topic create time DESC"; 


: $get topics res = mysqli_query(Smysqli, $get topics sql) 


or die(mysqli error($mysqli)); 


if (mysqli num rows($get topics res) < 1) í 
//there аге no topics, so say so 
$display block = "<р><еп>Мо topics exist.</em></p>"; 

} else í 
//сгеате the display string 
$display block «««END OF TEXT 
<table> 
<tr> 
<th>TOPICG TITLE</th> 
<th># of POSTS</th> 
</tr> 

END OF TEXT; 


while ($topic info = mysqli fetch array($get topics res)) í 
$topic id = $topic info['topic id']; 
$topic title = stripslashes($topic info['topic title']); 
$topic create time = $topic info['fmt topic create time']; 
$topic owner = stripslashes($topic info['topic owner']); 


//get number of posts 
$get num posts sql = "SELECT COUNT(post id) AS post count FROM 
forum posts WHERE topic id = '".$topic 14."""; 


$get num posts res = mysqli query($mysqli, $get num posts sql) 
or die(mysqgli error($mysqli)); 


while ($posts info = mysqli fetch array($get num posts res)) í 
$num posts = $posts info['post count']; 


} 


//add to display 
$display block .- «««END OF TEXT 
«tnr»? 
<td><a href-"showtopic.php?topic id=$topic id"> 
<strong>$topic_title</strong></a><br/> 
Created on $topic create time by $topic owner</td> 
«td class="num_posts_col">$num_posts</td> 
</tr> 
ЕМО ОР ТЕХТ; 

) 

//free results 

mysqli free result($get topics res); 

mysqli free result($get num posts res); 


56: /¿close connection to MySQL 


a: mysqli close($mysqli}; 

58: 

59: //close up the table 

60: $display block .= "</table>"; 
61: ) 

62: 7> 

63: «IDOCTYPE html» 

64: <html> 

65: <head> 


66: <title>Topics in My Forum</title> 
67: «style type="text/css"> 
68: table 1 


69: border: 1px solid black; 
70: border-collapse: collapse; 
71: } 

72: th { 

73: border: 1px solid black; 
74: padding: 6px; 

fo: font-weight: bold; 

76: background: #ccc; 

Tis } 

78: td { 

79: border: 1px solid black; 
88: padding: 6px; 

81: } 

82: .hum posts col { text-align: center; ) 


83: </style> 

84: </head> 

85: «body» 

86: <һ1>Торісв in My Forum</h1> 

87: «?php echo $display block; ?> 

88: <p>Would you like to «a href-"addtopic.html"»add a іоріс</а>?</р> 
89: «/body» 

90: </html> 
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ПООО00000009Форіс іпго ПД000005боріс іа0000000000000000 
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$topic омпег0000056гірѕІаѕћеѕ()05000000000000000000000 
0000 


00330003600Омплердроддрообророророоророводорб00000 
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d spare parts: 
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<?php 
include 'ch21 include.php'; 
doDB{); 


//check for required info from the query string 
if (!isset($ GET['topic id'])) 1 
header("Location: topiclist.php"); 
exit; 
) 


//create safe values for use 
$safe topic id = mysqli real escape string($mysqli, $ GET['topic id']); 


//verify the topic exists 

$verify topic sql - 'SELECT topic title FROM forum topics 
WHERE topic id = '".$safe topic 14."""; 

$verify topic res = mysqli query($mysqli, $verify topic sql) 
or die(mysqli error($mysqli)); 


if (mysqli num rows($verify topic res) < 1) { 
/ithis topic does not exist 
$display block = "<p><em>You have selected an invalid topic.<br/> 
Please «a href=\"topiclist.php\">try адаіп</а>.</еп></р>"; 
) else 4 
/iget the topic title 
while ($topic info = mysqli fetch array($verify topic res)) 4 
$topic title = stripslashes($topic info['topic title']); 
} 


f/fgather the posts 
$get posts sql - "SELECT post id, post text, 
DATE FORMAT(post create time, 

"ыр Зе %Y<br/>%r') AS fmt post create time, post owner 
FROM forum posts 
WHERE topic id = '".$safe topic id."' 
ORDER BY post create time ASC"; 

фое posts res = mysqli query(S$mysqli, $get posts 541) 
or die(mysqli error($mysqli)); 


//create the display string 
$display block = «««END OF TEXT 
<p>Showing posts for the <strong>$topic title</strong> topic:</p> 
<table> 
<tr> 
<th>AUTHOR</th> 
<th>POST</th> 
</tr> 
ЕМО OF. TEXT; 


while (%ро5%5 info = mysqli fetch array($get posts res)) í 
$post id = Sposts info[ post id']; 
$post text = nl2br(stripslashes($posts info['post text'])); 
$post create time = $posts info['fmt post create time']; 
$post owner = stripslashes($posts info['post owner']); 


//add to display 


56: $display block .- «««END OF TEXT 
57: <tr> 


58: <td>$post_owner<br/><br/> 

59: created on:«br/»$post create time«/td» 
60: <td>$post_text<br/><br/> 

61: <a href-"replytopost.php?post id-$post id"> 
62: <strong>REPLY TO POST</strong></a></td> 
63: </tr> 

64: ЕМО ОР ТЕХТ; 

65: } 

66: 

67: [{їТгее results 

68: mysqli free result($get posts res); 

69: mysqli free result($verify topic res); 

то: 

71: {iclose connection to MySQL 

72: mysqli close($mysqli}; 

73: 

74: //close up the table 

ro: $915р1ау block .= "</table>"; 

78: } 

77: ?> 

78: <!DOCTYPE html» 

79: «html» 

80: <head> 


81: <title>Posts in Topic</title> 
82: <style type="text/css"> 


83: table { 

84: border: 1px solid black; 
85: border-collapse: collapse; 
86: ) 

87: th í 

88: border: 1px solid black; 
89: padding: 6px; 

90: font-weight: bold; 

91: background: £ccc; 

92: ) 

93: td í 

94: border: 1px solid black; 
95: padding: 6px; 

96: vertical-align: top; 

97: } 

98: .hum posts col ( text-align: center; ) 
99: </style> 

199: </head> 

191: <body> 


192: «hi»Posts in Торіс</һ1> 

103: <?php echo $display block; ?> 
104: </bady> 

185: </html> 
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Posts in Topic 


You have selected an invalid topic. 
Please try again. 
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ПШШЦППШЦППро5 1а000000510005300005розі  гехії| 

$post create time[]$post ownerr[J[]][]stripslashes )ППОООООО 
ОПООО0000005розіз info Г розі гехі/1)0)000п126го D nib i LI 
ОДОХНАТМЕРЛОДОООП 
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ООООО000000000000000058000590000000Н MLO 
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00650000000м перо 0000075005аїзріау біоск ОДО0О000000 
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Showing posts for the How did you get started with technology? topic: 


jane(@)doe.com | I'm interested in knowing how people got started in technology -- did you tinker with 


household electronics? Did you learn about tt m school? Did your parents buy you а 
created on: computer tell you to have at it? 
Mar 22 2012 
01:05:47 РМ did you start hacking on things? 





REPLY TO POST 


021-6 ПППППИПП 


ОООО000000000000000000000000000000000000 


21.6 MUNI 


О000000000000000геріусорозі. рирДПОДОООО00000000000 
О000000000000021.60000000000000000000020003000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО000000000000000000 


000021.6 0000000000 


1: <?php 

2: include 'ch21 include.php'; 

3: doDB(); 

4: 

5: //check to see if we're showing the form or adding the post 

6: ІТ (15 POST) í 

71 // showing the form; check for required item in query string 

8: if (!isset($ GET['post id'])) 4 

9: header("Location: topiclist.php"); 

19: ехіт; 

11: ) 

12: 

13: //create safe values for use 

14: $safe post id = mysqli real escape string($mysqli, $ GET['post id']); 
1293 

16: //still have to verify topic and post 

17: $verify sql = "SELECT ft.topic id, ft.topic title FROM forum posts 
18: AS fp LEFT JOIN forum topics AS ft ON fp.topic id - 
19: ft.topic id WHERE fp.post id = '".$safe post і4."""; 
59: фмегіТу res = mysqli query($mysqli, Sverify sql) 

22: ог die(mysqli error($mysqli)); 

23: 

24: if (mysqgli пит rows($verify res) < 1) 1 

25: //this post or topic does not exist 

26: header("Location: topiclist.php"); 

27: exit; 

28: Y else [ 

29: //get the topic id and title 

30: while($topic info = mysqli fetch array($verify res)) 1 

31: $topic іа = $topic info[ topic id']; 

32: $topic title = stripslashes($topic_info['topic_title']); 

33: } 

34: 7» 

35: «IDOCTYPE html> 

36: «html» 

37: <head> 


38: <title>Post Your Reply in <?php echo $topic title; ?></title> 

39: </head> 

40: «роду» 

41: <hi>Post Your Reply іп <?php echo $topic title; ?></һ1> 

42: «form method="post" action="<?php echo $ SERVER['PHP SELF']; ?>"> 
43: «p»«label for-"post owner'»Your Email Address:«/label?«br/-» 

44: «input type-"email" id-"post owner" name-"post owner" $17е="40" 

45: maxlength-'158" гедилгед="гедилгед"></р> 

46: <p><label for="post_text">Post Text:</label><br/> 

47: «textarea id-"post text" name-"post text" rows="8" cols="4@" 

48: required="required"></textarea></p> 

49: <input type="hidden" name-"topic id" value="<?php echo $topic id; ?>"> 
50: «button type="submit" name-"submit" value-"submit"-Add Post</button> 
51: </form> 


52: </body> 

53: «/html- 

54: <рћр 

55; } 

56: /itree result 


Ea. maram 1- Paan mami lst Й Фаро Жам ағаға `Y = 


пузучла 1156 IcoUullipvecollly 15292], 


//close connection to MySQL 
mysqli close($mysgqli); 


: } else if ($ POST) | 


/ icheck for required items from form 
1f ((!$ POST[ topic id |) || (1% POST[ post text 1) || 
(18 POST['post owner'])) ( 

header{ "Location: topiclist.php"); 

exit; 


} 


/ | сгеајте safe values for use 

$safe topic id = mysqli real escape string($mysqgli, $ POST[ topic id']); 
$safe post text = mysqli real escape string($mysqli, $ POST['post text']); 
safe post owner = mysqli real escape string(Smysqli, $ POST['post owner']); 


¿iadd the post 
$add post sql - "INSERT INTO forum posts (topic id,post text, 
post create time,post ownerj VALUES 
('".$safe topic id."', '".$safe post text."'', 
now(),'".$safe post owner."')"; 
бада post res = mysqli query($mysoli, $add post sql) 
or die(mysqli error($mysqli)); 


//close connection to MySQL 
mysqli close($mysqli}; 


//redirect user to topic 
header("Location: showtopic.php?topic id-".$ POST['topic id']); 
exit; 
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e Post Your Reply in How dic 
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Post Your Reply іп How did you get started 
with technology? 


Your Email Address: 


Post Text: 


021-7 ОДОДО000 
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Posts in Topic 
€ С | © http://localhost/21/showtopic.php?topic_id=2 


к| м ~ 


Posts in Торіс 


Showing posts for the How did vou get started with technology? topic: 


jane(@doe.com | Im interested in knowing how people got started in technology -- did you tinker 


you a computer and tell you to have at it? 


REPLY TO POST 


пла able.com | Му parents gave me a TRS-80 when I was 11, and I played all sorts of text 
adventures and learned a little BASIC. I abways found computers fascinating, and 
used them whenever I could -- even when my school didnt! 
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| id, cat id, item title, item price, item desc, 
store Items | шщ Е Е й 
кет Image 
item id, item color 
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CREATE TABLE store categories ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
cat title VARCHAR (50) UNIQUE, 
cat desc TEXT 





); 


О0000000О5іоге Кет ОДІаДОООООО005000000000000000 
ООО0000000000000000000000000 
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CREATE TABLE store items 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
cat id INT NOT NULL, 
item title VARCHAR (75), 
item price FLOAT (8,2), 
item desc TEXT, 
item image VARCHAR (56) 


store item size[Jstore item соїогдДОДОДОООЗОДОДОДООПО 
ПООДООДООДООД0000000000000000000000000000000000000 
ПООДООДООДО0000000000000000 


CREATE TABLE store item size ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
item id INT NOT NULL, 
item size VARCHAR (25) 

): 

CREATE TABLE store item color ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
item id INT NOT NULL, 
item color VARCHAR (25) 

E 
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22.1.1 [|store categories; ||| 


ППППППвіоге categoriesUIUUUU3UUULhats[]shirts[ [books] 


INSERT INTO store categories VALUES 
('1', Hats', 'Funky hats in all shapes and sizes!'); 


INSERT INTO store categories VALUES ('2', 'Shirts', 'From t-shirts to 
sweatshirts to polo shirts and beyond.'); 


INSERT INTO store categories VALUES ('3', 'Books', 'Paperback, hardback, 
books for school or play.'); 


ИШИШШИИШШ TEILTE TE TEILTE TE] 
22.1.2 [|store Жеппл5[| ||| 


ООООО000000000ЗО000000000000000 


INSERT INTO store items VALUES ('1', '1', ‘Baseball Hat', '12.00', 
‘Fancy, low-profile baseball hat.', 'baseballhat.gif'); 


INSERT INTO store items VALUES ('2', '1', ‘Cowboy Hat', “52.00”, 
"179 gallon variety', 'cowboyhat.gif'); 


INSERT INTO store items VALUES ('3', '1', "Тор Hat', '102.00', 
'Good for costumes. , ‘tophat.gif'); 


INSERT INTO store items VALUES ('4', '2', 'Short-Sleeved T-Shirt ', 
112.00", '100% cotton, pre-shrunk.' , 'sstshirt.gif'); 


INSERT INTO store items VALUES ('5', '2', 'Long-Sleeved T-Shirt', 
115.00", ‘Just like the short-sleeved shirt, with longer sleeves.', 
'"lstshirt.gif ); 


INSERT INTO store items VALUES ('6', '2', 'Sweatshirt', '22.00', 
'Heavy and warm.', 'sweatshirt.gif'); 


INSERT INTO store items VALUES ('7', '3', 'Јапеј'5 Self-Help Book', 
12.00", ‘Jane gives advice. , 'selfhelpbook.gif'); 


INSERT INTO store items VALUES ('8', '3', ‘Generic Academic Book ', 
'35.00', 'Some required reading for school, will put you to sleep.', 
'boringbook.gif'); 


INSERT INTO store items VALUES ('9', '3', 'Chicago Manual of Style', 
'9.99', ‘Good for copywriters.', 'chicagostyle.gif'); 


QOCOOOOO00000"baseballhat. gif” рооооооооооовоовооваоваооовооооовооо 
0000000000 | 


22.1.3 [|store item sizer[J JL 
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INSERT INTO store item size (item id, item size) VALUES (1, Опе Size Fits All'); 
INSERT INTO store item size (item id, item size) VALUES (2,'0ne Size Fits All'); 
INSERT INTO store item size (item id, item size) VALUES (3,'0ne Size Fits All'); 
INSERT INTO store item size (item id, item size) VALUES (4, 5'); 

INSERT INTO store item size (item id, item size) VALUES (4,'M'); 

INSERT INTO store item size (item id, item size) VALUES (4,'L'); 

INSERT INTO store item size (item id, item size) VALUES (4,'XL'); 


22.1.4 [|store item color ||| 
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0000000 


INSERT INTO store item color (item id, item color) VALUES (1, гей”); 
INSERT INTO store item color (item id, item color) VALUES (1,'black'); 
INSERT INTO store item color (item id, item color) VALUES (1,'blue'); 
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000022.1 ПО00000 


1: <?php 

2: //connect to database 

3: mysqli = mysqli connect{" localhost", "јовизег", "somepass", "'testDB"); 

4: 

5: $display block = "<һ1>Му Categories</h1> 

6: <p>Select a category to see its items.</p>"; 

£i 

8: //show categories first 

9: $get cats sql = "SELECT id, cat title, cat desc FROM 

10: store categories ORDER BY cat title"; 

11: $get cats res = mysqli query($mysqli, $get cats 541) 

12: or die{mysqli error($mysqli) ); 

Tas 

14: if (mysqli num rows($get cats res) < 1) { 

19: $display block = "<p><em>Sorry, no categories to browse.</em></p>"; 

16: else í 

17: while ($cats = mysqli fetch array($get cats res)) í 

18: Фсаї id = $cats['id']; 

19: $cat title = strtoupper(stripslashes($cats['cat title'])); 

20: $cat desc = stripslashes($cats['cat desc']); 

21: 

22: $display block .= "<p><strong><a href=\"".$ SERVER['PHP SELF']. 

23: "?cat id-".$cat id."i"»",$cat title."«/a»«/strong»«br/»" 

24: .$cat desc."«/p»"; 

25: 

26: if (isset($ СЕТ| сәт id']) && ($ GET['cat id'] == $cat 14)) í 

27: //create safe value for use 

28: $safe cat id = mysqgli real escape string({$mysqli, 

29: $ GET['cat id']); 

30: 

31: /fget items 

32: $get items sql = "SELECT id, item title, item price 

33: FROM store items WHERE 

34: cat id = ‘".$cat_id."' ORDER ВУ item title"; 

35: $get items res = mysqli query($mysqli, $get items sql) 

36: or die(mysqli error($mysqli)); 

зү? 

38: if (mysqli num rows($get items res) < 1) { 

39: $display block = "<p><em>Sorry, no items in this 

40: category.«/em»«/p»"; 

41: ) else { 

42: $display block .= "<и1>"; 

43: while ($items = mysqli fetch array($get items гев)) í 

44: $item id = $items['id']; 

451 $item title = stripslashes(S$items[ item title']); 

46: $item price = $items['item price']; 

47: 

48: $display block .= "<li><a 
href=\"showitem.php?item id=". 

49: $item іа. "\ ">". $ітет title. "</a> 

50: (\$".$item price.")</li>"; 


51: } 


58: $display block .= "</ul>'; 
54: } 

55: //free results 

56: mysqli free result($get items res); 
Ју: 1 

58: } 

59: } 

61: //free results 

62: mysqli free result($get cats res); 

63: //close connection to MySQL 

64: mysqli close($mysqli); 

65: ?» 

66: <!DOCTYPE html> 

67: <html> 


69: 594% ому Categories</title> 
70: </head> 
71: «роду» 
72: <?php echo $display block; 7» 
73: </body> 
74: </html> 
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= | El w 
e My Categories 
= С” ©) http://localhost/22/seestore.php Ki м “А 
Му Categories 


Select a category to see tts items. 


BOOKS 
Paperback, hardback, books for school or play. 





HATS 
Funky hats in all shapes and sizes! 


SHIRTS 
From t-shirts to sweatshirts to polo shirts and beyond. 


022-1 00000 
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© Му Categories 
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Му Categories 


Select a category to see its items. 


BOOKS 
Paperback, hardback, books for school or play. 





HATS 


• Baseball Hat ($12.00) 
* Cowboy Hat ($52.00) 
• Top Hat ($102.00) 





SHIRTS 
From t-shirts to sweatshirts to polo shirts and beyond. 
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О000000000000000000000002 ЗОО0000000000000000000 
“add to саг "Ц00000000522.2П0005ћом ет. рћлрпоро 
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1: <?рһр 

2: //соппесЕ to database 

3: $mysqli = mysqli connectí("localhost", "joeuser", "somepass", "testDB"); 
4; 

5: $display block = "<һі>Му Store - Item Пета11</һ1>»"; 

6: 

7: /fcreate safe values for use 

8: $safe item id = mysqli real escape string($mysqli, $ GET['item id']); 
9: 


19: //validate item 
11: $get item 591 = "SELECT c.id as cat id, c.cat title, si.item title, 


12: si.item price, si.item desc, si.item image FROM store items 

13: AS si LEFT JOIN store categories AS c on c.id - si.cat ic 

14: WHERE 51.14 = '".$safe item id."'"; 

15: $get item res = туѕд1і query(S$mysqli, $get item 541) 

16: ог die(mysqli error(S$mysqli)); 

17: 

18: if (mysqli num rows(Sget item res) < 1) í 

19: //invalid item 

20: $display block .- "<p><em>Invalid item selection.</em></p>"; 

21: ) else ( 

22: //valid item, get info 

23: while ($item info = mysqli fetch array($get item res)) 4 

24; $cat id = $item info['cat id']; 

25: $cat title = strtoupper(stripslashes($item info['cat title'])); 

26: $item title = stripslashes($item info[' item title']); 

Er: $item price = $item info['item price']; 

28: $item desc = stripslashes(S$item info['item desc']); 

29: $item image - $item info['item image']; 

30: } 

31: 

32: {{таке breadcrumb trail & display of item 

33: $display block .- «««END OF TEXT 

34: <p><em>You are viewing:</em><br/> 

35: «strong»«a href-"seestore.php?cat id-$cat id'»$cat title«/a» 891; 
$item title</strong></p> 

36: «div style="float: left; "><img src="$item_image" alt-'$item title" 
/></ div> 

37: <div style="float: left; padding-left: 12px"> 

38: «p»«strong»Description:«/strong»«br/»$item desc</p> 

39: <p><strong>Price:</strong> i$$item ргісе</р> 

40: END OF TEXT; 

41: 

42: /#free result 

43: mysqli free result($get item res); 

45: {iget colors 

46: $get colors sql = "SELECT item color FROM store item color WHERE 

47: item id = '".$safe item id."' ORDER ВУ item color"; 

48: $get colors res = mysqli qguery($mysqli, $get colors sql) 

49: or die(mysqli error($mysqli)); 

50: 


913 if (mysqli num rows($get colors res) > 0) (í 


52: $display block .= "<p><strong>Available Colors:«/strong»«br/»"; 


53: while ($colors = mysqli fetch аггау(фдеї colors ге5)) í 
54: item color = $colors['item color']; 

55; $display block .= $item_color."<br/>"; 

56: } 

57: } 

58: /#free result 

59: mysqli free result($get colors res); 

60: 

61: {деф sizes 

62: $get sizes sql = 'SELECT item size FROM store item size WHERE 
63: item id - ".$safe item id." ORDER BY item size"; 
64: $get sizes res = mysqli query($mysqli, $get sizes sql) 

65: or die(mysqli error($mysqli)); 

66: 

67: if (mysqli пит rows($get sizes res) > 0) 1 

68: $display block .- "<p><strong>Available Sizes:</strong><br/>"; 
69: while ($sizes = mysqli fetch array(S$get sizes res)) 4 

70; $item size = $sizes[ ' item size']; 

Ti $display block .- $item size."<br/>"; 

72: } 

73: ) 

74: [[free result 

75: mysqli free result($get sizes res}; 

76: 

77: $display block .= "</div>"; 

78: 3 


79: //close connection to MySQL 
80: пув411 close($mysqli); 

81: ?> 

82: <!DOCTYPE html> 

83: <html> 

84: <head> 

85: <title>My Store</title> 

86: </head> 

87: <body> 

88: «?php echo $display block; 7» 
89: «/body» 

90: </html> 
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Му Store - Item Detail 


You are viewing: 


HATS > Baseball Hat 


h Description: 
Fancy, low-profile baseball hat. 


Price: $12.00 





Available Colors: 


blue 
red 


Available Sizes: 
One Size Fits All 
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CREATE TABLE store shoppertrack ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
session id VARCHAR (32), 
sel item id INT, 
sel item qty SMALLINT, 
sel item size VARCHAR(25), 
sel item color VARCHAR(25), 
date added DATETIME 


ОДбоброро0р0000001а0005ез5іоп табООДОДб0О0000000000 
ООО0000000000000 


П005ѕеѕѕіоп іароо000000000000000РНРО010о0000005е! “ 
ПОДООО0000000000000000000000000000000000000000 
date адаеад ДООД0000000000000000000000000000000000 
ПОДОДО0000000000000000000000000000000000000000 
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CREATE TABLE store orders ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
order date DATETIME, 
order name VARCHAR (100), 
order address VARCHAR (255), 
order city VARCHAR (58), 
order state CHAR(2), 
order zip VARCHAR(10), 
order tel VARCHAR(25), 
order email VARCHAR(100), 
item total FLOAT(6,2), 
shipping total FLOAT(6,2), 
authorization VARCHAR (590), 
status ENUM('processed', 'pending') 
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ОООО0000000000000000000000000000000000000000000000 


ОООО0000000000000000000000000000000000000000000000 
ОО000000000000 


ОООООО00000000000000000000000000000000000000000 
ООООДО00000000000000000000000000000000000000000000 
О000000000000000000005оге orders itemsT] 


CREATE TABLE store orders items ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
order id INT, 
sel item id INT, 
sel item qty SMALLINT, 
sel item size УАВСНАВ {25}, 
sel item color VARCHAR(25), 
sel item price FLOAT (6,2) 


sel *DEDUIDUDUUUL зе! Кет ресерр0000 
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session start(}; 
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39: «p»«strong»Price:«/strong» \$$item price</p> 


40: «form method="post" action-"addtocart.php"» 

41: END-OF ТЕХТ; 

42: 

43: /ifree result 

44: mysqli free result($get item res); 

45: 

46: ідеї colors 

47: $get colors sql = "SELECT item color FROM store item color WHERE 
48: item id = '".$safe item id."' ORDER BY item color"; 
49: $get colors res = mysqli query($mysqli, $get colors 541) 

50: ог die(mysqli error($mysqli)); 

512 

52: if (mysqli num rows($get colors res) > 0) í 

53: $display block .= "<p><label for=\"sel item color\"> 

54: Available Colors:</label><br/> 

55: «select id=\"sel item colori" name=\"sel_ item со1ог\ ">"; 
56: 

57: while ($colors = mysqli fetch array($get colors res}) í 
58: $item color = $colors['item color']; 

59: $display block .= "<option value=\"".$item color."i"»". 
60: $item color."</option>"; 

61: } 

62: $display block .= "</select></p>"; 

63: } 

64: 

65: /!free result 

66: mysqli free result($get colors res); 

67: 

68: [{ дет sizes 

69: $get sizes sql = 'SELECT item size FROM store item size WHERE 
79: item id = ".$safe item id." ORDER BY item size"; 
71: $get sizes res = mysqli query($mysqli, $get sizes sql) 

72: ог die(mysqli error($mysqli)); 

rs 

74: if (mysqli num rows($get sizes res} > @) { 

(5: $display block .= "<р><1аре1 for=\"sel item size\"> 

76: Available Sizes:</label><br/> 

те. «select id=\"sel item 51221" name=\"sel item size\">"; 

78; 

79: while (%55іге5 = mysqli fetch array($get sizes res)) í 

80: $item size = $sizes['item size']; 

81: $display block .= "<option value=\"".$item size."\">". 
82: $item size."</option>" ; 

83: } 

84: } 

85: 

86: $display block .- "</select></p>"; 

87: 

88: /{Тгее result 


ao: mronli Беда raowult+/Cnat слово rac: 


190: 


182: 
183: 


пуоч-<- 1 I vu І LOU LL PYE L емо І co} 5 


$display block .= " 
<p><label for=\"sel_item_qty\">Select Quantity:</label> 
«select id=\"sel item ату\" name=\"sel item qty\">"; 


for($i-1; $i«11; $1++) í 
$display block .= "<option value=\"".$i."\">".$i."</option>"; 
} 


$display block .= <<<ЕМО OF TEXT 

</select></p> 

<input type="hidden" name-'sel item id" 

value-"$ GET[item id]" /> 

«button type="submit" name="submit" value="submit"> 
Add to Cart</button> 

</form> 

</div> 


: END OF TEXT; 
: ) 


: //сіо5е connection to MySQL 
: mysqli close($mysqgli); 
2» 


: <!DOCTYPE html» 

: <html> 

: <head> 

: <title>My Store</title> 
: <style type="text/css"> 
118: 
119: 
120: 
121: 
122: 
123: 
124: 


label {font -weight: 6014; } 
</style> 
</head> 
<body> 
<?php echo $display block; ?> 
</body> 
</html> 
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Мұ Store 
- С! © http://localhost/23/showitem.php?item_id=1 KA” 
Му Store - Item Detail 
You are viewing: 
HATS > Baseball Hat 
Description: 
Fancy, low-profile baseball hat. 
Price: $12.00 
Available Colors: 
black |» | 
Available Sizes: 


One Size Fits All |» | 
Select Quantity: 1 [>] 


Add to Cart 
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000023.2 | addtocart.php[][] 


<?рһр 
session_start({); 


if (isset($ POST['sel item id'])) { 
//connect to database 
$mysqli = mysqli connect({"localhost", "joeuser", "somepass', "testDB"); 


//create safe values for use 

$safe sel item id = mysqli real escape string(S$mysqli, 
$ POST['sel item id']); 

$safe sel item qty = mysqli real escape string($mysqli, 
$ POST['sel item ағу! 1); 

$safe sel item size = mysqli real escape string($mysqli, 
$ POST['sel item size']); 

$safe sel item color = туѕд1і real escape string($mysali, 
$ POST['sel item color']); 


//validate item and get title and price 
$get iteminfo sql - "SELECT ет title FROM store items WHERE 
id - .$safe sel item id."'"; 
$get iteminfo res - тузды nic avait. $get_ iteminfo _sq1) 
or die(mysqli error($mysqli)); 


if (mysqli_num_rows($get_iteminfo_res) < 1) í 


//free result 
mysqli free result($get iteminfo res); 


//close connection to MySQL 
mysqli close($mysqli) ; 


//invalid id, send away 
header( "Location: seestore.php"); 
exit; 
} else { 
/ iget info 
while ($Sitem info = пу541і fetch array($get iteminfo res)) í 
$item title = stripslashes($item info['item title']); 


} 


/Тгее result 
mysqli free result($get iteminfo res); 


//add info to cart table 
$addtocart sql = "INSERT INTO store shoppertrack 
(session id, sel item id, sel item qty, 

sel item size, sel item color, date "i 

VALUES ("".5 COOKIE[ PHPSESSID']."' 
".$safe sel item id."' 
' .$safe sel item обу. , 
* $safe sel item size."', 
".Фѕағе sel item color."', пом ())"; 
$addtocart res = mysqli query($mysqli, $addtocart 541) 

or die(mysqli error($mysqli)); 


Br: //close connection to MySQL 


58: mysqli close($mysqli); 

59: 

60: //гедігесі to showcart page 
61: header("Location: showcart.php"); 
62: exit; 

63: ) 

64: 

65: У else í 

66: //send them somewhere else 

67 : header("Location: seestore.php"); 
68: exit; 

69: ) 


П2000000000000000000000000001000005оге | 
shoppertrack[]|] 
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000023.3 showcart.phpr[][] 


<?php 
session startí); 


/íconnect to database 


$mysqli = mysqli connect("localhost", "ioeuser", "somepass", "testDB"); 


$display block = "<h1>Your Shopping Cart</h1>"; 


{icheck for cart items based on user session id 
$get cart 541 = "SELECT st.id, si.item title, si.item price, 
56.561 item qty, 51.521 1tem si76, st.sol 1tem color 
store shoppertrack AS st LEFT JOIN store items AS si 
si.id = st.sel item id WHERE session id = 
'".$ COOKIE['PHPSESSID'].°'"; 
$get cart res = mysqli query($mysqli, $get cart sql) 
or die(mysqli error($mysqli)); 


if (mysqli num rows($get cart res) < 1) { 

¿print message 

$display block .- "<p>You have no items in your cart. 

Please «a href=\"seestore.php\">continuse to shop</a>!</p>"; 
) else ( 

//get info and build cart display 

$display block .- «««END OF TEXT 

<table> 

<tr> 

<th>Title</th> 

<th>Size</th> 

<th>Color</th> 

<th>Price</th> 

<th>Qty</th> 

<th>Total Price</th> 

<th=Action</th= 

</tr> 


ЕМО OF TEXT; 


while ($cart info = mysqli fetch array($get cart res)) í 
$id = $cart info[ id']; 
$item title = stripslashes($cart info['item title']); 
$item price = $cart info['item ргісе |; 
$item qty - $cart info['sel item qty']; 
$item color = $cart info['sel item color']; 
$item size = $cart info['sel item size']; 
$total price = sprintf("%.@2T", $item price * $item qty); 


$display block .- «««END OF TEXT; 

<tr> 

«td»$item title <br></td> 

<td>$item_size <br></td> 

<td>$item color <br></td> 

<td>\$ $item price <br></td> 

«td»$item qty <br></td> 

<td>\$ $total price</td> 

<td><a href="removefromcart.php?id=$id">remove</a></td> 
</tr> 


END OF TEXT; 


+ 


FROM 


ON 


58: $display block .= "</table>"; 
59: ) 

60: //free result 

61: mysqli free result(Sget cart res); 


63: //close connection to MySQL 
64: mysqli close($mysqli}; 
?> 


66: <!DOCTYPE html» 

67: <html> 

68: «head» 

69: «title»My Store</title> 
79: «style type="text/css"> 


71: table í 

72: border: 1px solid black; 
fa; border-collapse; collapse; 
74: } 

уз th í 

76: border: 1px solid black; 
771 padding: 6px; 

Lo. font-weight: bold; 

79: background: #ccc; 

80: text-align: center; 

81: } 

82: td ( 

B3: border: 1px solid black; 
84: padding: 6px; 

85: vertical-align: top; 

86: text-align: center; 

87: } 

88: </style> 

89: </head> 

90: <body> 

91: <?php echo $display block; ?> 
92: </body> 

93: </html> 
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000023.4 removefromcart.php||[] 


1: <?php 

2: Session startí(); 

а: 

4: if (і55е:(5 GET['id'])) í 

5: //connect to database 

6: $mysqli = mysqli connect("localhost", "joeuser", "somepass", "testDB"); 
ro 

8: //create safe values for use 

9: $safe id = mysqli real escape string($mysqli, $ GET[ id']); 
10: 

11: $delete item sql - "DELETE FROM store shoppertrack WHERE 
12: id = '".$safe id."' and session id = 
13: "".5 GOOKIE['PHPSESSID '"j 

14: $delete item res = mysqli query{$mysoli, $delete item sql) 
15: ог die(mysqli error($mysqli)); 

16: 

17: Г/сіове connection to MySQL 

18: mysqli close($mysqli); 

19: 

20: //redirect to showcart page 

21: header("Location: showcart.php"); 

2: exit; 

23: } else 4 

24: //send them somewhere else 

25: header("Location: seestore.php"); 

26: exit; 

27: } 

28: ?> 
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ОООО00000000000000000000000090000024.1200000000000000 
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000024.1 ОДДОО00000000 


1: «?php 
2: if ((lisset($ POST['month'])) || (lisset($ POST['year']))) { 
3 $nowArray = getdate(); 

4 $month - $nowArray['mon']; 

5: $year = $nowArray['year']; 

6: } else í 

Ti $month = $_POST['month']; 

8 $year = $ POST['year']; 

9: ) 

19: $start = mktime (12, 0, 0, $month, 1, $year); 

11: $firstDayArray = getdate($start); 

12: ?> 


000024 10ДО000000000000000000000000000000000000 
ООО00000000000000000000000000000 


020 00ОД000000000000попіпДуеаг)Отопевдуеаті0О 
П000000000000ткіите()000000000топуеаг 0000000 


0000000000000030009еЧа*е()000000000000000000000 
П0000топруеаг 0 $ топ О $уеа 0004 000 0000000000 
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24.1.2 [[IHTMLIT] 


ПППИППППИППИППППИППИППППИППИППППИППИПППӘЕГЕСТП 
ОДООД000Н ТМЕДОДОДООО ОО ОООО0О00000000000000000000000 
ООООД0О000000ОРПІОМПООООО5ЕРНЕСТООО000000024.20000 


000024.2 ОПОДОДОНТМІГО 


«?php 
if ((lisset($ POST['month'])) || (tisset($ POST['year']))) ( 


$nowArray = getdate{); 
$month = $nowArray['mon']; 
$year = $nowArray['year']; 
} else ( 
$month = $ POST['month']; 
$year = $ POST['year']; 
} 


: $start = mktime (12, 0, 0, $month, 1, $year); 
: SfirstDayArray = getdate($start); 


2> 

«1DOCTYPE html» 

<html> 

<head> 

<title><?php echo "Calendar:".$firstDayArray['month']." 
".SfirstDayArray['year']; ?></title> 

<body> 

<ni>Select a Month/Year Combination</h1> 

<form method="post" action-"«?php echo $ SERVER['PHP SELF']; ?>"> 

«select name="month'"> 

<?php 


: $months = Array("January", "February", "March", "April; "May", 


"June", "July", "August", "September", "October", "November", "December"); 
for (%х-1; $x <= count{$months); $х++) í 
echo"«option value=\"$x\""; 
if ($x == $month} { 
echo " selected"; 


} 
echo "»".$months[$x-1]."«/option»"; 
} 
9» 
</select> 
«select name="year"> 
<?php 


for ($x-1990; $x«-2020; $х++} 1 
echo "«option"; 
if ($x == $year) 1 
echo " selected"; 
} 
echo ">$x</option>"; 


} 


?> 
2. | | | 
«button type="submit" name="Submit" value="submit">Go!</button> 


: </form> 
: </body> 
: </html> 
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24.1.3 [ILLI 
ООО0000000000000000000000000000000024.300000000 
ОО00000000000 


0002000000000300064000000000024.200200000000000 
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НОЧО ОЦ 
000024.3 000000000 


<?рһр 
define("ADAY", (60%60%24)); 
if ((lisset($ POST['month'])) || (l!isset($ РОЗТ| уеаг'1))) í 


$nowArray = getdate(); 
$month = $nowArray['mon']; 
$year = $nowArray['year']; 
} else { 
$month = $ POST[ 'month']; 
$year = $ POST[ 'уеаг']; 
} 


: $start = mktime (12, 0, 0, $month, 1, $year); 
: $firstDayArray = getdate ($start) ; 


?> 
<!DOCTYPE html» 
<html> 
<head> 
«title»«?php echo "Calendar: ".$firstDayArray['month']." 
". $firstDayArray['year'']; ?></title> 
<style type="text/css"> 
table { 
border: ipx solid black; 
border-collapse: collapse; 


} 
th í 
border: 1рх solid black; 
padding: 6px; 
font-weight: bold; 
background: #ссс; 
} 
td 1 
border: 1px solid black; 
padding: 6px; 
vertical-align: top; 
width: 190px; 
} 
</style> 
<body> 


<hi>Select a Month/Year Combination</h1> 
<form method="post" action="<?php echo $ SERVER['PHP SELF']; ?>"> 
<select name="month"> 


: <?php 
: $months = Array("January", "February", "March", "April", "May", 


"June", "July", "August", "September", "October", "November", "December" }; 


: Тог (%х-1; $x <= count($months); $х++) í 


echo"«option value=\"$x\""; 
if ($x -- $month) ( 
echo " selected’; 


} 


echo ">".$months[$x-1]."</option>"; 


52: </select> 
53: «select name="year"> 


54: «?php 

55: for ($x-1980; $x«-2010; $х++) { 
56: echo "<option"; 

57: if (5х == $year) í 

58: echo " selected"; 

59: } 

60: echo ">$x</option>"; 

61: } 

62: ?> 


63; </select> 

64: «button type="submit" name-"'submit" value="submit">Go!</button> 
65: </form> 

66: «br/» 

67: <?рһр 

68: $days = Array("Sun", "Mon", "Tue", "Wed", "Thu", "Fri", 'Sat"); 
69: echo "«table»«tr2»in"; 

70: foreach ($days as $day) { 


ги echo "<td>". Фау. </Тй>\п"; 

fer ¢ 

73: for ($count-0; $count < (6*7); $count++) í 
74: $ЧауАггау = getdate ($start} ; 

r5: if (($count * 7) == 8) 1 

Tb. if ($dayArray['mon'] != $month) í 
TE: break; 

78: ) else { 

19: echo "</tr><tr>\n"; 

89: ) 

81: ) 

82: if ($count < $firstDayArray['wday'] || $dayArray['mon'] != $month) í 
83: echo "<td>&nbsp;</td>\n"; 

84: y else { 

85: echo '"«td»",$dayArray['mday']."«/td»Àn" ; 
86: $start += ADAY; 

87: } 

88: 

89: echo "</tr></table>"; 

90: ?> 

91: </body> 

92: </html> 
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(С) Calendar: March 2012 


€ > C QCntp//localhost/24/showcalendar.php El № 


Select a Month/Year Combination 


March [=] 2012/»| | бо! | 





















































024-2 ППППППП 


24.1.4 ПЛ 


ООО00000000000000000000000000000000000000000000 
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ООО0О0000000000000000000000000000000000000000000000 
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calendar емепїѕ0ЦО0000000000000000000000000000 


CREATE TABLE calendar events ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
event title VARCHAR (25), 
event shortdesc VARCHAR (255), 
event start DATETIME 
); 


000000000024. ЗООООООО00000000000000000000000000 
ОО0О0000000000000000000000000000000000000000000000 


000000000000000000000000360000«Ппеад > 00000000000 
JavaScript 


<script type="text/javascript"> 
function eventWindow(url) { 
event popupWin = window.open(url, 'event', 'resizable-yes, scrollbars=yes, 
toolbar=no,width=4@@,height=400' } ; 
event popupWin.opener = self; 


</script> 


[JavaScript 00000400 x А00ДОДООДОООС0О00000982000 
000008500000/амазст РеЕООПОООООПООДОДОДОДОО00 
Јама5сгірПО0000000000000000емепё.рпроо000000000000 


echo "<td><a href=\"javascript:eventWindow( event.php?m-".$month. 
"Samp ;d=".$dayArray['mday']."&amp;y=$year'};\">".$dayArray['mday']."</a> 
«br/»«br/2".Sevent title." '«/td»in"; 


П00000емепё.рпрроб000000000000000000000000000000 
ОО00000000000000003000000000000%_6ЕТ'т"000000 
5 СЕТРаЧО0000005 GETT y" JE] 


П0000емепё.рпробо00000000000000000000000000000000 
ООО00000000000000000000000000000000000000008400еіѕе 
О0000000000000еіѕеПооосоооо000000000000000000000000 
ООО000000000000 


y else í 
$mysqli = mysqli connect("localhost", "joeuser", "somepass", "testDB'); 
ФСһҺКЕуепі sql = "SELECT event title FROM calendar events WHERE 
month(event_start) = балын AND 
ЕА A start) = '".$dayArray['mday']."' 


D year(event start) = '".$year."' ORDER BY event start"; 
$chkEvent res = mL le query($mysqli, SchkEvent 841) 
ог die(mysqgli error($mysqli)); 
if (mysqli num rows($chkEvent res) > 0) í 


while ($ev = mysqli fetch array($chkEvent res)) í 
$event title = stripslashes($ev['event title']); 


} 
) else { 


$event title = ""; 
} 


echo "<td><a href=\"javascript:eventWindow( ' event. php ?m=" . $month . 
"&amp;d=".$dayArray['mday']."&amp;y=$year');\">". 
$dayArray['mday' ]."«/a»«br/»«br/»".S$event title."'«/td»in';j 
unset($event title); 


$start += ADAY; 


0000024.4000000000000000000 


showcalendar withevent.php[] 
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<?php 
define("ADAY", (60*60*24)); 


if ((!isset($ POST['month'])) || (!isset($ POST['year']))) í 


$nowArray = getdate(); 
$month = $nowArray[ топ" |; 
фуваг = $nowArray['year']; 
} else 14 
$month = $ POST['month']; 
$year = $ POST['year']; 
} 
$start = mktime (12, 0, 9, $month, 1, Зугаг); 
$firstDayArray = getdate($start); 
?> 


: «IDOCTYPE html> 


<html> 
<head> 


«title»«?php echo "Calendar: ".$firstDayArray['month']." ". 


$firstDayArray['year'] ?></title> 


<head> 
<style type="text/css"> 
table { 
border: 1рх solid black; 
border-collapse: collapse; 
} 
th ( 
border: 1px solid black; 
padding: 6px; 
font-weight: bold; 
background: ccc; 
} 
td | 
border: 1рх solid black; 
padding: 6px; 
vertical-align: top; 
width: 190px; 
} 
</style> 


«script type="text/javascript"> 
function eventWindow(url) ( 


event popupWin = window.open(url, 'event', 
resizable-yes,scrollbars-yes,toolbarzno,width-409,height-2409'); 


event popupWin.opener - self; 
} 
</script> 
<body> 
<hi>Select a Month/Year Combination</h1> 


<form method="post" action="<?php echo 5 SERVER['PHP SELF']; ?>"> 


<select name="month"> 


<?php 
$months = Аггау("Чапиагу", "February", "March", 
"July", "August", "September", "October", "November", 


for ($x=1; $x <= count($months); $x++) 4 
echo'«option value=\"$x\""; 
if ($x == $month) 4 


anha " ealartad" = 


"December" ); 


ыы в 


56: 
DZ: 
58: 
59: 
60: 
61: 
62: 
63: 
64: 
65: 
66: 
67: 
68: 
69: 
70: 
ra i- 
72: 
73: 
74: 
75: 
78: 
£f: 
TB: 
79: 
80: 
81: 
82: 
83: 
84: 
85: 
86: 
87: 
88: 
89: 


м MEN чм, er М” ا‎ Мм MA 5 


} 
echo ">". $months[$x-1]."</option>"; 
} 
2> 
</select> 
«select пате= "уеаг" > 
«?php 
for (%х-1990; %х<-2020; $х++) { 
echo "<option"; 
if ($x == $year) í 
echo " selected"; 
} 
echo ">$x</option="; 
} 
?> 
</select> 
«button type="submit" name-"submit" value-"submit"»Go!«/button- 
</form> 
<br/> 
<?php 
$days = Array("Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"); 
echo "<table><tr=\n"; 
foreach ($days as $day) { 
echo "<th>$day</th>\n"; 
} 


for ($count=@; $count < (6*7); $count-*) í 
$dayArray = getdate($start}; 


if (($count * 7) == 0) { 
if ($dayArray['mon'] != $month) í 
break; 
} else í 


echo "</tr><tr>\n"; 


; 


90: 


91: if ($count < $firstDayArray[' wday'] || $dayArray['mon'] != $month) í 

92: echo "«td»&nbsp;«/td»in"; 

93: ) else { 

94: $mysqli = mysqli connect("localhost", "joeuser", "5отера55", 
"testDB"); 

95; $chkEvent 541 = "SELECT event title FROM calendar events WHERE 

96: month(event start) = '".$month."' AND 

97: dayofmonth(event start) = '".$dayArray['mday']." ' 

98: AND year(event start) = '".$уеаг."' ORDER BY 

event start"; 

99: $chkEvent res = mysqli query($mysqli, $chkEvent sql) 

100: ог die(mysqli error($mysqli)); 

181: 

182: if (mysqli пит rows($chkEvent res) > 0) í 

103: while ($ev = mysqli fetch array(S$chkEvent res)) í 

184: $event title .= stripslashes($ev['event_title']."<br/>"; 

105: ) 

146: ) else í 

107: $event title = ""; 

108: } 

189: 

118: echo "<td><a href=\"javascript:eventWindow( 'event.php?m=".$month. 

111: "&Samp;d=".$dayArray['mday']."&amp;y=$year');\">". 

112: $dayArray['mday']."</a><br/><br/>".$event_title."</td>\n"; 

113: 

114: unset(S$event title); 

115: $start += ADAY; 

116: } 

117%-2 

118: echo "</tr></table>"; 

119: 


120: //close connection to MySQL 
121: mysqli close($mysqli); 

122: 7» 

123: </body> 

124: </html> 
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e Calendar: March 2012 


c С! @ http://localhost/24/showcalendar_witheventphp 


Select a Month/Year Combination 


March — |+] 2012|»| | Go! | 
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<!DOCTYPE html> 

<html> 

<head> 

<title>Show/Add Events</title> 
<body> 

<hl>Show/Aqd Events</h1> 

<?php 


mysqli = mysqli connect("localhost", "joeuser", "somepass", “testDB"}; 


//add any new event 
if ($ POST) 4 


//сгеаїе database-safe strings 
$safe m = mysqli real escape string($mysqli, $ POST['m']); 
$safe d = mysqli real escape string($mysqli, $ POST['d']); 
$safe y = mysqli real escape string($mysqli, $ POST['y']); 
$safe event title = mysqli real escape string($mysqli, 
$ POST['event title']}; 
$safe event shortdesc = mysqli real escape string($mysqli, 
$ POST['event shortdesc']); 
$safe event time hh = mysqli real escape string{$mysqli, 
$ POST['event time hh']); 
$safe event time mm = mysqli real escape string(S$mysali, 
$ POST['event time mm']); 


7 


$event date = $safe y.".".$safe m."-".$safe d." 
".$safe event time hh.":".$safe event time mm.":00"; 


$insEvent sql - "INSERT INTO calendar events (event title, 
event shortdesc, event start) VALUES 


('".$safe event title."', '".$safe event shortdesc. 


".фемепі date."')"; 
$insEvent res = mysqli query($mysqli, $insEvent sql) 
or die(mysqli error($mysqli)}; 


y else 4 
$safe m = mysqli real escape string($mysqli, $ GET[ т 1); 


1) 
$safe d mysqli real escape string($mysqli, $ GET['d']); 
$safe y = mysqli real escape string(S$mysqli, $ СЕТІ у 1) 


//create database-safe strings 


3 


} 


/fshow events Tor this day 
$getEvent sql = "SELECT event title, event shortdesc, 


date format(event start, '%1:%1 %р') as fmt date 


FROM calendar events WHERE monthíevent start) 
'",$sate_ m."' AND dayofmonth(event start) = 
'".$safe d."' AND year(event start) = 
"".$safe y."' ORDER BY event start"; 


51: 
52: 
53: 
54: 
55: 
56: 
57: 
58: 
59: 
68: 
61: 
62: 
63: 
64: 
55: 
66: 
67: 
58: 
69: 
70; 
71: 
72: 
ҮЗ: 
тА: 
75: 
78: 
tél 
78: 
79: 
80: 
81: 
82: 
83: 


$getEvent res = mysqli query($mysqli, $getEvent 541) 
or die(mysqli error($mysqli)); 


if (mysqli num rows($getEvent res) > 0) í 

$event txt = "<ul>"; 

while (бем = @mysqli fetch array($getEvent res)) 4 
$event title = stripslashes($ev['event title']); 
$event shortdesc = stripslashes($ev['event shortdesc']); 
$fmt date = $ev['fmt date']; 
$event txt .- '«li»«sstrong»".$fmt date."«/strong»: 

"event title." «br/»".$event shortdesc."«/li»'; 


) 

Феуепі txt .= "</ul>"; 

mysqli free result($getEvent res); 
y else 14 

Sevent txt = ""; 


) 
‘f close connection to MySQL 
mysqli close($mysqli); 


if ($event txt !- "") ( 
echo "<p><strong>Today's Events:«/strong»«s/p- 
$event txt 
«hr/»"i 

) 


ff show form for adding ап event 

echo «««END OF TEXT 

<form method="post" action="$ SERVER[PHP SELF] "> 
«p»«strong»Would you like to add an event?</strong><br/> 
Complete the form below and press the submit button to 
add the event and refresh this window.</p> 


<p><label for="event_title">Event Title:</label><br/> 
<input type="text’ id="event title" name="event title" 
Size="25" maxlength="25" /></р> 


«p»«label for="event shortdesc">Event Description: </label><br/> 

<input type="text’ id-'event shortdesc" name-"event shortdesc" 
біге-"25" maxlength="255" /></p> 

«Tieldset- 

<legend>Event Time (hh:mm}:</legend> 

«select name-"event time hh"- 

END OF TEXT; 


for ($x=1; $x <= 24; %х++) í 
echo "<option value=\"$x\">$x</option>" ; 


) 


: echo <<< ЕМО ОР TEXT 

: </select> : 

: «select name-"event time пт"? 

: «option value-"9800'»-00«/oprtion- 

: «option value="15'">15</option> 

: «option value-"30'»30«/option- 

: «option value="45">45</option> 

: </select> 

: </fieldset> 

: «input type="hidden" name="m" value-'$safe т' > 
: <input type="hidden" name-"d" value-"'$safe d"> 
: <input type="hidden" name="y" value-'$safe у" > 


: «button type="submit" name-"submit" value="submit">Add Event</button> 
: </form> 

: END ОР TEXT; 

: 7> 

: </body> 

: </html> 


04500052000000000000000000000000000000000000000 


00540006 700000000000000000000000000000000790001140 
ОО000000000000000 
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6 Show/Add Events - Google Chrome 


| ©) localhost/24/event.php?mz3&d- 1B&y- 2012 


Show/Add Events 


Today's Events: 


• 1:00 РМ: Go to the Zoo 
Типе to see the Red Pandas! 








— 


Would уоп like to add an event? 
Complete the form below and press the submut button to add the event and 
refresh this window. 


Event Title: 
Event Description: 
Event Time (hhmm): 


1 [=]: [00 f=] 
| Add Event | 
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| @ Show/Add Events - Google Chrome 


©) localhost! 2A/event.php 


Show/Add Events 
Today's Events: 
e 1:00 РМ: Go to the Zoo 
Time to see Ше Кей Pandas! 


* 4:00 РМ: Leave the Zoo 
Time to go home. Х 


Would vou like to add an event? 
Complete the form below and press the submit button to add the event and 
refresh this window. 


Event Title: 


Event Description: 
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ОО00000000000000000090024.600П000000000000000 
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1: class date pulldown | 
2: public $name; 

3 public $timestamp = -1; 

£ public $months = аггау("Чап", "Feb", "Mar", "Apr", "Мау", "Jun", 
5: "Jul", "Aug", "Sep", "Oct", "Nov", "Оес"); 

6: public $yearstart = -1; 

ré- public $yearend = -1; 

8 
9 
9 
1 


function date pulldown($name) 4 
$this->name = $name; 


ПШШП2ПШПП$пате[[ПЦПШШШШПНТМ1Ї. setect inani 
$timestamp[]DEDBEDI DU МІХОДОО0400050000Ф9 months 000000 
0000000000000000005уеагаеіагі5уеагепа руде рр 7000000 
001 000000000000000000000000000000 


ОДОООО000000000000000005 патеррдододорпоошроо00000 
ООО000000000000000000000000000024.6000000 


000024.6 ОДОДОДОДО0 


та: function setDate global( ) { 

13: if (!$this-»setDate array{$GLOBALS[$this->name])) { 
14: return $this->setDate timestamp(time()); 
151 

16: return true; 

17: } 

18: 

19: function setDate timestamp(Stime) í 

29: $this->timestamp = $time; 

21: return true; 

22: } 

23: 

24: function setDate array($inputdate) í 

251 if (15 array($inputdate) && 

26: isset(Sinputdate['mon']) && 

271 isset(S$inputdate['mday']) && 

28: isset(Sinputdate['year'])) 1 

29: 

30: $this->timestamp = mktime(11, 59, 59, 
31: $inputdate['mon'], $inputdate['mday'], $inputdate['year']); 
32: return true; 

33: 

34: return false; 

351 } 


ППШШПЦШШПЦШП$еїОаїе_їїтєе$їатр()ПППШШПП19ПЦП22[П 
О0009МІХПО0000000000%їтеѕёатрооб00000000000000000 


setDate апау())000240003500000000000000003000 
поп идауПуеаг р о00000000009есаастерррдрододороодоо 
П0000005ѕеёраѓе аггау()0000000000000000000 


аггау ("тдау"=> 25, "топ'=>3, "уеаг"=> 2012); 


ПО0О0Ооеёааќе() 000000000 


getdate( 1208052013}; 


ОО00000000000000000000000000топдтааууеаг0000 
О0000ткЕте()0000000000000000000000$%теѕёатрі00 


setbate діоба| 00000120002 "ООООО000000000000 
5 патерОДО0О00000000000000000005ебОаєе array  ОДО00000 
ОДОО0О00000000000000000005 і ппе5сапаррДод L IILI III 


ООО0000000000000000000000000024.600000000000000 
ОО0О00000000000000000000000000 


000024.6 О00000000) 


38: function setYearStart(S$year) í 


37: $this-»yearstart = $year; 

38: } 

38; 

40: function setYearEnd($year) £ 

41: $this->yearend = $year; 

42: } 

43: 

44: function getYearStart() 4 

45: if ($this->yearstart < 0) { 

46: $nowarray = getdate(time()); 
47: $this->yearstart = $nowarray['year']-5; 
48: } 

49: 

50: return $this->yearstart; 

51: H 

52: 

53: function getYearEndí) 1 

54: if (91115 ->увагепа < 0) { 

55: $nowarray = getdate(time()); 
56: $this--»yearend = $nowarray['year']*5; 
57: 

58: return $this->yearend; 

59: I 


setYearStart()|]setYearEnd )ППОООППООЗ 6004300000000 
бррордороророраесуеагькат )П0100%уеагѕёагє ПППИПИПИПОООД 
ПППоегтүеагогагОПИ ПЫППППФуеагвғаг де еагЕпа () 
ОДО0000000 


00000024.6000000000000000000000000 


000024.6 DO) 


60: function output() 4 


61: if ($this->timestamp < 9) í 

62: $this->setDate global(); 

63: } 

64: $datearray = getdate($this->timestamp) ; 

65: $out = $this->day_select($this->name, $datearray}; 

66: $out .= $this->month_select($this->name, $datearray) ; 

67: $out .= $this->year select($this->name, $datearray); 

68: return $out; 

69: } 

70: 

243 function day select($fieldname, $datearray) { 

Ta: $out = "<select name=\"$fieldname"."['mday']\">\n"; 

73: for ($x=1; $x<=31; $x++) { 

74: $out .= "<option value=\"$x\"". ($datearray[ 'mday' ]=={$х) 
75: 2" selected":"").">".sprintt("%@2d", $x) ."</option>\n"; 
r5 ) 

ТЕЗ $out .= "</select>\n"; 

78: return $out; 

79: } 

80: 

81: function month select($fieldname, $datearray) ( 

Ba: Gout = "<select name=\"$fieldname"."['mon']\">\n"; 

83: for ($x = 1; $x <= 12; $x++) { 

34: Sout .- "<option value=\"".($x)})."\"". ($datearray[ 'топ' ]=={$х) 
85: 2" selected": ""),."> ",$this->months[$x-1]."</option>\n° ; 
86: } 

87: $out .= "</select>\n"; 

88: return $out; 

89: } 

90: 

91: function year select($fieldname, $datearray) í 

92: $out = "<select name=\"$fieldname"."['year']\">"; 

93: $start = $this-»getYearStartí); 

94: $end = $this->getYearEnd(); 

95: for ($x= $start; $x < $end; $x++) { 

96: $out .= "<option value=\"$x\"".($datearray['year' ]=={$х) 
97: 7" selected": "").">".$x."</option>\n"; 

98: } 

99: $out .= "«/select»in"; 

190: return $out; 

191: ) 

182: ) 


output  ОДОДО00000000006000069000000005 і тезсатр 
00000П5еєФасерроДОО000000005 и ппев5сатрО000000-1000 


зе Паје діора| ДОД000000000000000П9еєсаасе ПП ПП ПП 
ООО00000000000000 


day 5еїес(00000710007900000000НТМІ ѕеіесє 000000 
0003 11 ILU LIL He pere n DIETE BICI EIE] da tea rra y E TET] 
ППППППППППГПГППор тот ПП ППТ LIsprintf()( IILI LI II I! 
1П900000топЁћһ ѕеіес)Пуеаг сбегес ОП ПППӘӨІІ ОТТТППП 
О000000000000000 


ОООО0000000000400000000000000000000000000000000 
О0000000000000009аѓе ритаомидуддоДОДОПдате pulldown 
ОЗ000000000 


ОООО0000000000000000000000000000000000000000000 
О000000оиёриє)О000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
0000000000000000000Дуеаг 5еїес 0000 


000024. 700000000000000000000000000000000000000 
24.6 ОДПРНРОДОООДОДОООД0ОДОДОДОД0ОДО 
date риаомп.сІіаѕѕ.рће000000000000%еБо50000000000000 
0024. "ООО0000000000000 


ППП124.7 [date pulldown[] 


1: <!ПОСТҮРЕ html> 

2: <html> 

3: «head» 

4: <title>Using the date pulldown Class</title> 
5: </head> 

6: <?php 

7: ainclude{ "date pulldown.class.php"); 

8: $date! = new date pulldown("fromdate") ; 

9: $date2 = new date pulldown("todate"); 

19: $date3 = new date pulldown("foundingdate") ; 
11: $date3-»setYearStart("1972"); 

12: if (empty($foundingdate)) { 

13: $date3->setDate аггау(аггау('таау'-»26, 'топ'=>4, 'уваг' ->1984)); 
14: ) 

15: 12 

16: <body> 

17: «form» 


18: <p><strong>From:</strong><br/> 
19: <?php echo $datel-»output(); ?></р> 


21: <p><strong>To:</strong><br/> 
22: <?php echo $date2->output(); ?></p> 


24; <p><strong>Company Founded: </strong><br/> 
25: <?php echo $date3-»output(); ?></р> 


27: «button type="submit" name="submit" value="submit ">Submit</button> 
28: </form> 


29: </body> 
30: </html> 


о0060000000даге риаомп.сІаѕѕ.рһпрп0100000000000000 
ООДО0000000000000000000000 "Teun d ing d ate [III LI IILI III! 
О00000000000000002000000019 2000120000000000000000 
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О Using the date pulldown С 


€ С! ©) http//localhost/24/dateselector withclass.php КІ ғ a8 
From: 


25 || | Маг || | 2012|+| 


To: 
25 || | Маг |.| 2012|»| 


Company Founded: 


26 >| Apr |»| | 1984 |» | 


Submit 
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ӨШ 
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3[]date ритпаом и ПДОДОДОДООреУіс 00 
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1[]mktime() 
2Цоеїааїе() 
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ПППШШИШШП 
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А40000000000УУеББОДООООДООО0О000Н ТРООООДОДОД00000 
ОООО0000000000000000000000000000000000000000000000 
0000 


5ПАрасһерО0000000000000000000000000000000000 


ООООО00000000000000000000Н T ТРООООООООО000000000 
ООООО0000000000000000000000000000000000000000000000 
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000000 
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АрасһерОО0000000000000000000000000000000000000 
ОООО000000000000000000000000000000000000 


Арасһеро0зО0000000000000000000000АчёһМате[ 
AuthType[]Require[] 


АйЕРМаплерДОДОО0О000000000000000000УУебородбрб0О0 
ООО0000000000000000000000000 


АчћТуреро0000000000000000000 


Кеашгер00000000000000000000Аеаиге user iii ll 
ур000000Веаціге огоор05000000000000000 


Require user joe bob 
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Require group employee contractor 


ОО0О00000000000000000000000000000000000 


Require valid-user 
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ОПООООБОО0О000000000000000000000000000000000000000000000000000: 
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mod auth Араспедоррророооооооооооооооооооооооооо 
HLEJUNIXTELLLILI/etc/passwd[j/etc/groups[i]L]L] 
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OOL 
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ОО000000000000 


admin: LFrlxqg8Q6Ra6 


ОМ пасом в ООО0МО5О00000000 


admin:$apri$Ug3..... $jvTedbQWBKTfXsn5jK6UX/ 
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web: admin joe Daniel 
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htpasswd. exe ПП IILI II II) 
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Пипих/ОМІХДОО00000000000000000000000 


/usr/local/apache2/bin/htpasswd -c file userid 


Дртеррдрор00000000000Оч5епіаД ПП 
ПОООООД000000000Ці пих/ОМІХОДОДОООО 


/usr/local/apache2/bin/htpasswd -c /usr/local/apache2/conf/htusers admin 


ПППППППППП/ивгИоса/арасһе2/соп”/һивзегеПППППП 
admin 
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htpasswd -с "C:\Program Files\Apache Software Foundation|iApache2.2confihtusers" 
admin 


-СПО00000ћраѕѕумаро0000000000000000000000000000 
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О0000000000000000000000%еБроо00000000000000000 
ОООО0000000000000000000000000000000000000000000000 
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000025.1 DB 


: <Directory /usr/local/apache2/htdocs/private> 
: AuthType Basic 

: AuthName "Private Area" 

: AuthUserFile /usr/local/apache2/conf/htusers 
: Require valid-user 

: </Directory> 


Ooh WwW — 
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ОО00000000000000000000000000000Араспероо0000000 
ОО000000000000000000000000000000000тоа_аиёһ абтПП 
ООООО000000000000000000000000000000000000000000000 
mod auth dbm[TTmiApachetriiiiiimApeacher I III! 
|)--enable-module=dbmUUUUUUUUUULUL 


100000 


mod auth dbmUUUUUUUUUUAuthD BMUserFilel] 
АшћлоВвМбгоирРедррророооооооооооооовоооооооооооооооО 
ПООДООДО0Д000000000000 
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АраспедррДОДО МІХОММ паом'Б ПОДООООООДОДРЕХпАа0О000 
ОДОДОО00000000000000000АраспедудрдбіаДОДОСОС0О00000000 
ОО00000000000000000 


htdbm -c databasename userid 
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0000000 


htdbm -x databasename daniel 
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поа_ассез5 ДОООООДО0О00О00000000000000000001Р0000 
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О00000Аомрепурооооо00000000000001РО00000000000 
00000000 


1ОДОТРОДОД/ 000 
ОООО0000001ТРОООООООО000000000 


Allow from 19.0,0.1 10,0,0,2 10.0.0.3 


ПОВЕНООНОЕРООНОВОВЕУЧОВОВЕТРИВОВОВОНОВОВОЦЕТРИЕЕ 
ООООО00000000000000001Р000000000000000 


Deny from 19.0 


ОО00000000010.0000000010.0.1.0010.0.0.1П 


ОООД000ТГРООООООООТРООООООДООДООООООО0О0000000000000 
0000000 


Allow from 10.0.0.0/255, 255. 255.0 


ОДОДІРО010.0.0.1010.0.0.201010.0.0.254Г 


ОДООДОО000000200000000000000000000000000000 


Allow from 10.9.0.0/24 


20000000/0000 


ОО0000000000000000000000000АПом from example.com 


ПорОммлм.ехатр!е.сотПтоо.ехатр!е.согт ||] 


ОДОДОДОДООО00Арасреддодододобдома00000Но5ЕіМатетоскиреяд до x 
ООО0000000 | 


ОО00000000000000000000000000000000О0епу«О0000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ОО000000000000ОП95егАдепепор00000 


BrowserMatch MSIE iexplorer 
репу from env-iexplorer 
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ООО000000000000000 
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ПООа 100000000000000Аом from а репу from андоооО 
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ОДОДОО0АПом Обепуррообр0000000гаег ОДООО0О0000000 
ОО0000000000000000000000000000000репуПАомЦАПом[] 
Ррепу[Миїиаі-РаПигеПрепуПАомПоОгаег о000000000000000 


1 ОепупАЙоми 


ОБепуПАПом ППВепуППППАНом ПППОООООООВепуПАНом ПП 
000АПомПрепуроо00000000000000000000000000000000000 
Репурооо0000000000000000А1ом000АПом000000000 
АПом'ПДООО0О0000000000000 


000025.20000000Арасперрр00000000Оехатріе. сот ППП 
ОО0/огімаєеррДОДОДО00000000 


000025.2 дОрепубАТом 00000 
1: «Location /private> 
2: Order Deny,Allow 
3: Deny from all 
4: Allow from 16.0.0.0/255.255.255.9 example.com 
5: </Location> 


2 JAllow|]Deny 


Allow[]|Deny[ I JAllow[ ППВепуППППОООППАЙоми,ВепупППпП 
ПАПомПрепуроо00000000000000000000000000000000000 
АПомПО000000000000000000епур000репуроо000000 


О0000000Аомрепур000гаег АПомУ б епудррор 0000000 
ООО0О0000000000000000000 


000025.ЗО00000000000000000 


000025.3  ОДАТом,Оепуд00000 


1: «Location /some/location/> 
2: Order Allow,Deny 

3: Allow from all 
4 
S 





: Deny from host.example.com 
: </Location> 


3[]|Mutual-Failure 
ОМифиа!-РайигеППППОООООООВОВАЙ м 000000000Оєепудб 
0000000000000 
25.4 (ЦАрасће [||| 


ОО00000000000000000000000000005аєѕғуроооо000000 
ОО000000000000000000005аёѕғупо00000000а!000апур 


Satisfy а ТООООДОД000000000000000000000000000000 
Прату апупо000000000000000000000000000000000000 
ULL] 


ОДООО0О0000000000000000000000000000000УУе6000000 
ООД000000іпеегпеє 0000000000000000000025.40000000 


000025.4 ОДОДОДО00000 





: «Location /restricted> 
: Allow from 19.0.0.0/255.255.255.0 
: AuthType Basic 
‚ AuthName "Intranet" 
: AuthUserFile /usr/local/apache2/conf/htusers 
: Require valid-user 
: Satisfy any 
: </Location> 


O 40 л = 
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ООО0О000000000000000000000000000000000000000000 
ООДО00000Н T ТРООООВЕ ТОНЕАРОООООООНООЦ 


«Limit ДООООООО0Д000000000000000000000000000000 
ОДОДОДООООДОЕТПРО5 ТПРУТПОЕТЕТЕПОСОММЕСТПОРТІОМЗГ) 
ТКАСЕЦРАТСНЦРКОРҒІМОПРКОРРАТСНПМКСОЦЦСОРҮГ 
MOVE[JLOCK[] UNLOCK[] 


<LimitExcept>||[ IILI ПП ПППІШПИП 
ПП 


000025.5000000Араспердрооро0000« (іпаїсь 0 
< ит Ехсер > ОООДООООДО00000000000000000000000РОТО 
ОДООО00000000000000000000000000 
http://httpd.apache.org/docs-2.2/ mod/core.html ПАрасће | 


ПП 


000025.5 00000008 


1: <Directory /home/*/public html» 

2: AllowOverride FileInfo AuthGonfig Limit 
3: Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec 
4: «Limit GET POST OPTIONS PROPFIND- 

5: Order Allow,Deny 

6: Allow from all 

т: </Limit> 

8: «LimitExcept GET POST OPTIONS PROPFIND- 
9: Order репу, Allow 

18: Deny from all 

11: </LimitExcept> 

12: </Directory> 


[0100000000000000сооке[00000000000000 
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CREATE TABLE auth users ( 
id int NOT NULL PRIMARY KEY AUTO INCREMENT, 
f name VARCHAR(50), 
1 name VARCHAR(50), 
email УАВСНАВ (150), 
username УАВНСНАВ (25), 
password VARCHAR ( 4 1) 


ОДДІМ5ЕВТОПДайн В users вабріеддДДбуопп Doe[|[ 000000 
ППЕтайП Шоһпоаое соға ПЦооеПППППаоерав<П 


INSERT INTO auth users VALUES ('1', ‘John’, ‘Doe’, ‘john@doe.com', 
'jdoe', PASSWORD( 'doepass ' ) ) i 


ППІМБЕКТПИПИППИПИППППРАЭЭУУОКБОППИПИППИПИППІП 
ІМ5ЕЕТООООООО00О00000000000000000000410000000 


ПППППачЕһ ч5ег5 0000000000Ораз5угогіад ДДО00000000 


——— (sate sm ЕЕ ae de ie дынын о eta РЕ ЕЕ ЕЕ ЕР vocis РЕ de + 
| username | password | 
Ip jg шз а ЕЕ due xe SE Е se mE mde Жыш ee + 
| jdoe | *0AAD744979343D58A7F17A50E514EGAD6533D84B | 
€ POS + 


ООООО0000000000000000000000000000000000000070 
ОР ОООО000000000000000000000000000000000000000000000 
ОООО000000000000000000000000000000000 
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ОО000000000000000000000000000000000000000000000 
000000025.6000 


000025.6 П00000 


ОЈ ب‎ c FE ww = 


со 


<!рОСТҮРЕ html> 

<html> 

<head> 

<title>User Login Form</title> 

</head> 

<body> 

<hi>Login Form</hi> 

«form method="post" action-"userlogin.php"- 

«p»«label for="username'><strong=username: </strong><br/> 


: «input type="text" id-"username" name-"username" /></label></p> 

: <p><label for="password'">=<strong=password:</strong><br/> 

: «input type="password" id-"password" name-"password" /></label></p> 
: «button type="submit" name="submit" value="login">Login</button> 

: </form> 

: </body> 

: </html> 


О000000000001о9іпғогт.ћтО000000000000000\%еюрп 


000000000000000000000000000Оч5егіодіп ph pETEETETETUL 
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000025.7 000000 


СО ч Ch Ch Fw n — 


ш 


о N юг е Мм Nes = = = == = = — — 
Ca Von C» л ~ о — €3 оно Od C£ [Гу — © 


о іп 02 02 ою Go Фо 
~ у Ол — 


къ ~ ~ ROG 
бо MO (л OQ I د‎ © 


: $username = mysqli real escape string($mysqli, $ POST['username']); 
: $password = mysqli real escape string($mysqli, $ POST[ 'password']) 


сә со 
(e 


«?php 

//check for required fields from the form 

if ((lisset($ POST['username'])) || (lisset($ POST['password']J)) ( 
header( "Location: userlogin.html"); 
exit; 


) 


//connect to server and select database 
$mysqgli = mysqli connect("localhost", "joeuser", "somepass", "testDB") 
ог die(mysqli еггог()); 


/fuse mysqli real escape string to clean the input 


2 


{ / сгеаје and issue the query 


: $sql = "SELECT f name, 1 name FROM auth users WHERE 


username = '".S$username."' AND 
password = PASSWORD( ".$password."')"; 


: $result = mysqli query($mysqli, $sql} or die(mysqli error($mysqli)); 


{iget the number of rows in the result set; should be 1 if a match 
if (mysqli пит rows(S$result) == 1) í 


#1117 authorized, get the values of f name 1 name 
while ($info = mysqli fetch array($result}) í 

$f name = stripslashes($info[' f name']); 

$1 пате = stripslashes($info['l name']); 


} 
[већ authorization cookie 
setcookie("auth", "1", 0, "/", "yourdomain.com", 9); 
ffcreate display string 
$display block = " 
<p>",.$f name." ",$1 name." is authorized!«/p» 
«p»Authorized Users’ Menu:</p> 
< u L > 
<li><a href=\"secretpage.php\'>secret раде</а></11> 
<ful>"; 

t else | 
/fredirect back to login form if not authorized 
headerí("Location: userlogin.html"); 
exit; 

} 

j iclose connection to MySQL 


: mysqli close($mysqli); 
: 7> 


49: «IDOCTYPE html> 

50: «html- 

51: <head> 

52: <title>User Login</title> 

53: </head> 

54: <body> 

55: <?php echo $display block; 7» 
56: </body> 

57: </html> 
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ОЗООДО0О000000000000000000005. POS П'изеглате' Jr] 
9 POST['password'JLHLIBODH DD D ОДОДОС0О00000000000000000 
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ООООО0000000000000000000000000000000 


02 ЗОДООООООД00000000000000000000000000000000000 
0000001000000000002600029ПОптуздії fete. array OUITIDIEILILI 
ООО000000000000000000 
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соокіе Д00035000400О00000000000000000000000000000000 
Об000000420004500000000000000000000000000000000000 
ПП 
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= [=] | X | 
[=] User Login 
€ С О http://localhost/25/userlogin.php A 
John Doe 1s authorized! 


Authorized Users’ Мепи: 


* secret page 
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OOUsecretpage. риРрОД000000000000Осоокіе ji IILI I i] 


25.6.3 [auth cookie 


О0000000000000ачёћ соокіе ПП ПП 
000000000000025.80000 


[25.8 [auth cookie 


1: «?php 

2: if ($ COOKIE['auth'] == "1") í 

3: $display block = "<p>You are an authorized user.</p>"; 
4: 1 else í 

Бү ГР гедлгесЕ back to login form if not authorized 
6: header{ "Location: userlogin.html"); 

i. exit; 

8: | 

9. 7> 

19: «!DOCTYPE html» 

11: <html> 

12: <head> 

13: <title>Secret Page</title> 

14: </head> 

15: <body> 

16: <?php echo $display block; ?> 

17: </body> 

18: </html> 
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[=] Secret Page 


€ C |Qnttp//localhost/25/secretpage.php а, 





You аге ап authorized user. 
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ОООО000000000000000000000000000 
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ООООО000000000000000000000000000000000000000 
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1П00000000000000000000000000000000 
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ИЦ 


1 ПОООО000000000000000000000000А расперророорб00000 
ОООО00000000000000000000000 


2 ООООО00000000000000000000000055.00000000000000 
ОООДО0000000000000000000000НЙ17Т7РОДООООООООО00000000 
О0000%еБро00нтміО0соокіеро00000000000000 


ЗПѕеѓсоокіе()000000000соокіе000000000һеааег()00000 
[Set Соокіеб 
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00000000 
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• ПООООООО000000000000 
ОО0000000000000000 
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1000000000----00000 
2 ДО0000000----О0О000000000000000 
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ОООО0000000000000000000000000000000000а79б OU 
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ПАрасһер000000000000000000000000000000000000 
This Is the client address ФАӘПІПППППППТҺІ5 is the client 


address 10.0.0.2П000000000000%ароооо000001Р000000026- 
ТО0ДО000000000000000 


[26-1 00000 


00000 
00000000 
ПОВОВОВЕРОВ 


ПОВООООВООООЕТРНОВООООВОООВООВОВОООВЕРОВОВОВ 
ОДОООО МПОО0000000000Арасһер00000 
НоѕМатеіоокирѕП10000000000000000000000000 
ОООО000000ІРОООД0000 


III Od enti ПП ПП IILI III! 
00000 


ОООО00ОДІРОО 


П000епу магіабіе о оДб000000000000 
DLE 0000000 (ime. format УОДДОДОДОДОМІХ strftimeQ000 
ПШ ШГПАрасһе[[Подге$о!уеППППППШП 


оооооовоооооооо 





%\ О0000000000000 


ППОѕеСапопісаіМате 100000 


ОО00000000000х0000000000000000000000000А+00 
ОООО0000000000000000000А-000000000 


0000000 


% | | 
пески name?c [1110С00іе_патеПсоокіеП 


ПОООООНТТРОНТТР5 
СЕТПРОЗ ТПРОТОООГО 


% 000000000000пеааег патердродобробборб00000000 
theader пате }і | О00000000000000000 


О0000000000а ?000 
ППОКШШИШП 
HAT ТРОДОООООООООДО000000000 


%b[]%B ОООООО0000000000000000000000000000000000000 
Дроро0009є600000-009е8000000 


000000000000000 
ПП 


0000000000пеааег namen 001 


0000000Араспе000000000000000000000000000004 


О000000Сопатоп Log Forman 1 ППППППППППППИПУуеогі 1 
В В О О О ОВ 


'®һ %1 Su %% \"%Г\" %>5 %6" 


o | & 
3 EE 


C | | 


| 


لا 





LLIPI LI L lidenta[II II LIIHTTPII III 
ООООО0000000000000000000000000000000 


ПОООООбОО ер ://ww w.w3.0rg/Daemon/User/Config/Logging.html oooow3coo 
ОО0000000000 | 


ООООО000СЕРОДО 


10.0.0.1 - - [19/Jan/2012:17:32:43 -@500] "GET / НТТР/1.0" 200 1101 


ОООД000000000-039 Format ООООООООООО00000000000000 
ОООО000000000000000000000000000 


П000000АрасһпеПроо00000000с-РО000000000соттоп 


LogFormat ‘Ssh 51 Su t \"%г\" 525 зр" common 


ОООООООО00000оо РогтаєО0000000000000000000000 
О000000001ғапѕтегіоорооо000000000000000000000000000 
ПП 


1 |НоѕМатеіоокирѕ[ 


О0000000000Арасперо000001РО00Арасһеро00000000м5 
ОООДО000ТРОООООООДООО00ОО000000000000000000000 
Но5/Матецоокире5  ДОДОДОДПООО0О000М5 HI 


HostNameLookupsUUUUUUUUUUUUUUUon[off[ldou ей ППП 
off Jdouble[]H EJIEILI LIA растер РРООООООООООООвОООО РООО 
http://httpd.apache.org/docs-2.0/dns-caveats.htm!l 0000000 
ООООООДО00000000000000000000000А Ном репуррооороооооо 
ППаоче DNS[J JL HostNameuLookups| |[ JI I) 


ЦЦНо5 Мате ооКкир5ЦПЦЦПЦПЦПОПЦЦаони р !еЦПЦПАрасһеЦПЦЦЦППП 
ПШШЦПШШЦПШПЦПШШШЦПШШЦШШППШШШПППНО5ХМате оокКкир5ЦППЦПШШППП 
ПЦПЦППШШПППШПНО5 Мате оокир5[ПППШШПИШИШШПШШИШШИШПШШШШПП 
АраспедроодрдДО0ТРОООООД 0000 00000000001РООДОСОО0О0"О 
Apache" QUUUUU0UUUUUUUUUREMOTE_HOST(QUCGIQUO 


2 |IdentityCheck|] | 


бО0000000000001депсабдрдЗ ОООООСО0О000000000 
IdentityCheckl|[  ПППопПот дДООД00000000000000000000000 
Обб0р000000000000000000000000000000000000000097210000 
ОООСЕРОДООООД Чей ай TETDBIDIEIETEI DIDI ILE ]R EE p ://w w w. rfc- 
editor.org/rfc/rfc1413.txt [RFC 14131 


30000 


ООО0000000000000000000000000000000а9е ПОО0000000 
ООООО0000000000000000000000000000000000000000000000 
ОО000000000000000-0 


ОООО0000000000000000004000000000000000000005011 
ООО000000000000000000000000000000 


5400 ,501{User-agent}1 


ОООД0000000000007 О00000000000000000 


51:4049,501105ег-адепі рі 


26.1.2 [JII 


ПШШШПАраспеППППШПШШШШШИШЇТгап5їеп одП 
Си5тоттооЦППШШПИШППгап5Тег ОодППППШПШШПШИШШП 
LogFormat[] I III I L L iLogFormat[i( III II II CIT I I! 
ООООО0О00000000000С12РО0 


ППИПИПИПИПИПоадҒогтай Тгапвтегі (од ПОДОДОДОДОДОДОДО 
ООССРООООДОО000000 


LogFormat "%һ %1 %и %t \"%г\" 5525 %6 \"%S{User-agent}i\"" 
TransferLog logs/access log 


Custom ооППШПШШИШШИШШШШШШШШШШИ ШШ ШШШ 
ООО0О000000000000000000000000000 


0000000 


LogFormat "%һ 51 џи 51 \"%r\" %>5 5р \"%s{User-agent}i\"" myformat 
CustomLog logs/access log myformat 


ООО000000000000 


CustomLog logs/access log "ЗП 51 %u %Т \"S%r\" %>5 $b \"S{User-agent}i\"" 


Custom од ОООО0О00000000000000000000000000000000 
ОООО000000000007 7 ОО00000000000000000 


ООООООО0000000000061РО)|РЕСОООООО 


SetEnvIf Request URI "(i.gif|i.jpg)$" image 
GustomLog logs/access log common env-!image 


Uhttpd. сол ОООООДОО0ОДОДОД0000000000РАРООСООООООДОООДООО000000 


26.1.3 (ТП 


TransferLog[]CustomLog[ ДП ОО0О000Д0000Ї0000000000000 
ООДАрасперроророобооодоро0б00000000000000000000000 
ООО000000000000000 


ОООО00000000000000000000000000000000000000000 
АраспеПгогаїетод5 ДПОДОДООД0О0000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОООО0000000000000000000 


ОДОДОДО000000000000002распеордроорооододцоміхорро 
ОДООгооєООДОО00000000000001000У95егрорООООДОДПУЗееГОО0ОО 
[]nobody[]www[] 


26.2 (ТАрасһе(ППП 


ПППППППИПАрасһеП ПП EI E D HA pa eh ec rr TTE] 
ОООС61Д00000000 


ООООО0000000000000000000001РОООООООО0О000000000 
HT ТРУОООООООО0О0ОО00О00000000000009МІХОДОООООООООО 
syslog ПОДООДОММІ паом5 ПДОООООООУ/і пасм ПОДО0О00000 
УМ паом'5 ПДОДОО0000ЕггопПоа ПООО00000000 


26.2.1 ПООО000000 


ООООО0000000000000000000000000000000000000000000 
ОД000000001:95000000094МІХО)ДДеггог Іод ДУМ паом ПП 
error.log[ 000000 


ErrorLog logs/my еггог log 


26.2.2 MOLL 


ОДОДО000000000000007 |” 00000Арасһерооб00000000000 
ООО00000000000000000000000 


ErrorLog "|/usr/local/bin/someprogram" 


26.2.3 syslog[| ll 


DUNIXTIBBOCUDUBOGUUSy sleg rina db UNI XTTTUCTE 
UUUsyslogd ДОДО00000000О5у51039001/0саї7/ П00000000000000 
ПОДО00000000Озузіод:асіїї ку ООО0ДОО000000Озузіо400000П 
mail[Juucp[]localO[]local 1r ПОДОДОДО00000000000О5уз10900000 
ПППтап вусіода тап 5зуз!ода.сопт дД0000Озу5109000000 


ErrorLog syslog:local6 


26.2.4 | одіемеї! | | 


АрасперорообОДО000000000000000000000000000000000 
00000000 0391. емеїррооборОПО0О00О0000000000000000000 


126-20 од емеТД ДОДОДООООА pa ch ерордодододовоод 
годі емеї Ом ати ОПОООДАрасєперророоророророророобо00000000 
О0000000000000009ериП 


emerg 


alert 


crit 


error 


notice 


info 


debug 


= 
а 
— 
> 


026-2 


Emergencies[][] 


ПП ——[000000 


00000000 


0000 
0000 


0000 


О000000 
00000 


Арасће ПППСод(еме |] 






Child cannot open lock file. Exiting 


getpwuid: couldn't determine user name from 
uid 


socket: Failed to get a socket, exiting child 


Premature end of script headers 


Child process 1234 did not exit, sending 


another 


SIGHUP 


httpd: caught SIGBUS, attempting to dump 
core in[] 


Server seems busy, (You may need to increase 
StartServers, or Min/MaxSpareServers) 


Opening config file... 





26.3 (ПАрасће [|| 


АрасһеППО000000000000АрасһеПр00000000000000000 
П00000АрасперосЕғО00000000000000000000Арасһер 


26.3.1 ППО 


ПООООС000000000НоѕМагтеіоокирѕПО000000000000000 
ПОО000Ноѕ МатеГоокирѕПООо#1О0000000000001ІРО0000000 
ПОПОМХПОООО јодгезомедиц мл паом5ПОДіодгезоїме.ехеб) 
ПООО0000001РООООООООО 


іодге5оїме ПП пп ПП 
ОДОДОО0009 NIX Windows ООДОДОДОДО000000 


logresolve < access. log > resolved. log 


ООООО000000000000000000000000000000000000000 


26.3.2 [ПЦ 


ОД000УУеврорббо0ООО0000000000000000000000000000 
ООО0000000000000000000000 


ОАрасперродооодрооророророоросодорорбодоодДоро 
ООО00000000000000000000000 


Apache[J]TEUNIX[][]rotatelogs[][]T Windows] ПП 
rotatelogs.exe[JDD BB ml ПП EN DIDI D COOL 


OOOOOOOOUTC(Coordinated Universal ТїтеЦЦЦЦПП)ЦППППППППП 
ULL] 


TransferLog "|bin/rotatelogs /var/logs/apachelog 86400" 


О000000000000000000000000/маглодь0000000086400пПП 
0000000 





ОООДОД000000000000000000000000М000000000000МумОоситепіа ПП 
Ул паом в00000000 


ПППППППЭОППИПИПИПППӘ erf ti плпероД С0000000960000000 
ПЦгоате!о05ППППППППИШИШПШИПИШИШПШИШШИПИШП 


TransferLog "|bin/rotatelogs /маг/104985/араспеїодят *sd у 86400" 


ОООО0000000000000000000000 
О0рОр000000079є 000000000000000000000000000000 


26.3.3 (ULL 


ОООО0000000000000000000000000000000000000000000 
ООО0О0000000000000000000 


ООО0О0000000000000000000000000000000000000000000 


HLIMWebalizer(http://www.mrunix.net/webalizer/ )[Jawstats 


(http://awstats. sourceforge.net/ )[]WusageLFILLELLILILILILILILILILILIL 
[]http://www.boutell.com/wusage/ 00 


26.3.4 [| II] 


О00000МХОВ000Арасһер000а!о000000000000000000 
ОО0О0000000000000000 


tail -f logname 


ОООіодпатедрарасперродорооб0ОПО00000000000000000 
ООО000000000000000 


ПООДООДООДООДО0000000000000000000000000000000000 
UUUScanErrLodUUUUUUUUUUUUURNttp ://www.librelogiciel. 
com/software/ ПППП 


26.4 [ID Ba b BT TET 


ОМу5О СООООООО0000ОРНРОООООООООООО0О000000000000 
ОО00000000000000000000000000000000Араспепоо0000000 
ООООО0Д000000000000000000000000000000000000 


26.4.1 ПИ 


ОООО000000000000000000000000МУЗО9СО0О00О00000000 
access їгаскегП0000100000000000000000000 


CREATE TABLE access tracker ( 
id INT NOT NULL PRIMARY KEY AUTO INCREMENT, 
page title VARCHAR(58), 
user agent TEXT, 
date accessed DATE 


E 


ОООО0000000000000000000 


26.4.2 ППРНРППП 


ОООО0000000000000000000000000000000000000000000 


ОО0000000000000026.100000000000000 Дассевзз гаскег о 


ON A ВБ соого = 


000026.1 00000000 


<?php 

//set up static variables 

$page title = "sample page A"; 

$user agent = getenv( HTTP USER AGENT '); 


//connect to server and select database 
Фту541і = mysqli connect{" localhost", "јовизег", "somepass", "testDB") 
or die(mysql еггог()); 


: //сгеаїе and issue query 
: $sql = "INSERT INTO access tracker (page title,user agent,date accessed) 


VALUES ('$page title', '$user agent', now())"; 


: $result = mysqli query($mysali, $sql) or die(mysqli error($mysqli)); 


: //close connection to MySQL 
: mysqli close($mysqli); 
: 2> 


ООООО0Д00000000000000000000000000000000000000 


раде ЕНТеПДОДОДОДООО0О 


П000000ѕатріе1.рһро500000000000000026.1000000000 


01026.2000000 


000026.2 ППНТМІГП 


<!ПОСТҮРЕ html» 

<html> 

<head> 

<title>Sample Page A</title> 
</head> 

<body> 

«п1»8атріе Page А</11> 
<p>blah blah blah.</p> 
</body> 

0: </html> 


— (O CO ы OOF WN — 


ОДОООО000000000000000000О9раде неТепдродОдууев ОД 
ОО000000000000000 


26.4.3 [IIL 


[access {гаскег IILI L IILI пп ИП 
2 ӘП ППТ ПИПИППИППИППППИППИППППИППИППППИППГИПТГІГІ 
ULL] 


000026.3 ОДО00000 


O N 001 + сорго = 


«?php 
/ iconnect to server and select database 


$mysgli = mysqli connect("localhost", "joeuser", "5отера55", "testDB") 


ог die(mysqli еггог()); 


//1ssue query and select results for counts 


$count sql = "SELECT count(page title) AS p count FROM access tracker"; 


$count res = mysqli query($mysqli, $count sql) or 
die(mysqli error($mysqli)); 


while ($count info = mysqli fetch array($count res)) í 
$all count = $count info['p count']; 


) 


//issue query and select results for user agents 

$user agent 541 = "SELECT DISTINCT user agent, count(user agent) AS 
ua count FROM access tracker GROUP BY user agent 
ORDER BY ua count desc"; 

$user agent res = mysqli query($mysqli, $user agent sql) 
or die(mysqli error($mysqli)); 


/ istart user agent display block 
$user agent block = "<ul>"; 


//loop through user agent results 
while ($row ua = mysqli fetch array($user agent res)) { 
Фиѕег agent = $гоу ua[ user agent |; 
$user agent count = $row ua['ua count |; 
$user agent block .= " 
<11>".$иѕег agent." 
«ul» 
<li><em>accesses per browser: ".$user agent count."«/em» 
«ful» 
</li>"; 


) 


//finish up the user agent block 
$user agent block = "</ul>" ; 


//issue query and select results for pages 


$page title sql = "SELECT DISTINCT page title, count(page title) AS 
pt count FROM access tracker GROUP BY page title 


ORDER BY pt count desc"; 
Фраде title res = mysqli query($mysqli, $page title sql) 
or die(mysgli error($mysqli)); 


//start page title display block 
браде title block = "<ul>"; 


//loop through results 


wha la f arai ~ + - пау вел za la +=+ ~ |А T3 үч уз суза г £ via лач == =. badela mam tT \ r 


оф. WILLS (ром pL = тузції іскс аглаујфрачо_ стеле |v25jJ 1 


213 $page title = $row pt['page title ']; 
Бе $page count = $гом pt['pt count |; 
53% $page title block .- " 

54: «li»".$page title." 

393! «ul» 

56: <li><em>accesses рег раде: ".$page count."</em> 
57: </ul> 

58: “КЕ”, 

59: } 

69: 

61: //fanish up the page title block 

62: %раде title block .= "</ul>"; 

63: 


64: //close connection to MySQL 
65: mysqli close($mysqli); 


66: ?> 

67: <!DOCTYPE html» 
68: «html» 

69: «head» 


79: <title>Access Report</title> 

71: </head> 

72: <body> 

73: <hi>Access Reports/hi» 

74: =<p><strong>Total Accesses Tracked:</strong> 
75: <?php echo "$all count"; ?></p> 

76: <p><strong>Web Browsers Used:</strong> 
77: <?php echo "$user agent block"; ?></p> 
78: <p><strong>Individual Pages:</strong> 
79: <?php echo "$page title block"; ?></p> 
80: </body> 

81: </html> 


ОЗО000000000000000ассеѕѕ ёгаскег000000700080000 
ОО000000000150001900000000000000220000000000000000 
ОО00000000025000340000000000000000003 70000 


Пп400)044ПО0000000000000000004 700000000000000000 
ОООО00000059000059П000000000000000000000000000620000 


П00000000000ассеѕѕгерогё.рһро0000000000000%еоп00 
ОО0000000000000000000026-1000000000000000000000000 


ОО000000000 


[E] Access Report 


€ C © http://localhost/26/accessreport.php 


Access Report 


Total Accesses Tracked: 40 
Web Browsers Used: 


е МогШа/5 0 (Windows NT 6.1; WOW64) AppleWebKit/535.7 (KHTML, like Gecko) 
Chrome/16.0 912.75 Safan/ 535.7 
© accesses per browser: 19 
е Моліїа!5.0 (Windows NT 6.1: WOW64; гу:9.0.1) Gecko/20100101 Firefox’9.0.1 
o accesses per browser: 13 
е МогШа/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0) 
° accesses per browser: 8 


Individual Pages: 


• sample page В 
© accesses per page: 25 
* sample page A 


о accesses per page: 15 





026-1 ПОООО0000000 


О00000000Арасһепо00000000000000000000000000000 
ОДОД000Му5ОРО0рООО000000000000000000000000000000000 
00000000 


26.5 || 


О00000000Арасһпепо00000000000000000000000000000 
ОООО00000000000000000000000000000000000000000000 
АрасһерПО00000000000000000 


ООДОО0О000000000000ОРНРОДООООМУу 5ОС0О000000000000 
ОДООДОО000000000ОРНРОДООООООО00000000000 


26.6 О&А 


ОТПООО00000000 


АДООООООООООООООООООООООООООООООООООООвОООООООО 
ОООО000000000000Н МЕОДОООООО00000000000000000000000 
ОО0000000000000000000 


26.7 (ПП 


ООООО0Д00000000000000000000000000000000000000 


ӨШ 


10000000000000000%еооо0000000000000 
2 В0000000000000000 


JLIHEIILILILILIL]]A pa che[][HE]EIL]HostNameLoo kupsoffr | 


ИЦ 


О О О О О О TEIL 
ОДОО0О00000000000000005есепмітроррододводод 


SetEnvIf directive: 


SetEnvIf Remote Addr 10\.@\.@\. intranet 
CustomLog logs/access log "%һ 51 би 5% \"%г\" 5525 Sb" lintranet 


2 ПО00000000000000000000000000000000000000000000 
ОО00000000000000000 


SetEnvIT Request URI "(\.gif|\.jpeg}$" image 
CustomLog logs/access log common env=!image 
GustomLog logs/images log common env-image 


З000НоѕМатеіоокирѕоп00000000000000000000000 
ПІРООООООООВОООООООООООООООООООООООооОООооооороооо00 
ОО0000000000000000 


ӨШ 


ТООООО0000000000ОРНРОДОООООООООООДОО000000000000 
ООО00000000000000000 


2 ПОООД0000000000000000000000000000000000000000 
OOL 


0270 0000000 


ОО000000000 


• ПООООООД0000000000 
• ПООООООДО000000000000 


World Wide WebQ]Q00000World МмлаероодоооооооРнео 
МУу5ОТПООДО000О00000000УУеводродб0б00О000000000000000 
ООО0ОО0000000000000000000000000000 


27.1 00000000 


ООООО0000000000000000000000000000000000000000 
\меопоо00000000000000000000000000000000000000000000 
О00%Уебр000000000000000000000000000 


° ПООООО000000000000 
° ПОООООО0О0000000000000 


ОООО0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОО000000000 


ОО0ОО000000000000000000000000000000000000000000 
ПООДО00000000000У/еборооорддроб0ороррорроророподроб 
German Іосаї'е0)0000Сегтап locale ПП ПП 1 
ООДО0000000000000000000000000000000000000000 


Austrian locale[] 


ОООО000000000000000000000000000000000000000000 
ПП 


27.2 0000 


ООО0О000000000000000000000000000000000000000000 
ОобрДррб0ороррдороорбородродорородрасооо090о0о00000000000 
ОО000000000256000000А5СПДОООООО0000000000000000 


ОО000000002560000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
000000 Токуо ПООООО0000000000000500000000000500000000 
О000000000000000000оиПкуочП00000000000000040000 


ОООО000000000000000000000000000000000000000000 
учеб ПОДООООДОУУеБоОООООООДООДО0ООДОДОС0О00000000000000 
00000000 


ООО0О0000000000000000000000000000000000000000000 
Учеб ПООДООДО 0 ОДОДО0О0000000000000000000000000000000 
О0000000000000005# ЈІ5П0ТР-8000000000000150-8859- 


1 ПОО0000000000000150-8859-1ППО0000000000000000000000 
Д005піЄ ЛЬ ТР-ООДОООООДОДОДОДО0000000 


МодіакепроОб000000000000000000000000 
http://en.wikipedia.org/wiki/Mojibake IUUUUUUUCONtent- 


суреДСопіепі-Іапдчаде ПпДОД00000МЕТАДООООООДОДОДОДОП 
ОДОД0О0000000000000000000000000МЕТАДООООДО Пеааего 00 
ООО0О000000000000000000000 


header( Content-Type: text/html;charsetz-I15S0-8859-1"); 
header("Content-Language: еп"); 


OOUR TMES0OOOOUOOU 


«html lang="en'> 
«meta charset-'ISO-8859-1"'- 


ОООО000000000000000000000 


header( Content-Type: Техр/Ппіті;спаг5еї-150-8859-1" ); 
header("Content-Language: de"); 


ОООНТМЕ5О000000 


«html lang="de'> 
«meta charset=" 150-8859 - 1 "> 


ООО0О0000000000000000000 


heacer{ "Content-Type: text/html;charset-Snift 415”); 
heacer{ "Content-Language: ja"); 


ОООНТМЕ5О0О00000 


«html Тапд="ја"> 
«meta charset-"Shift JIS'> 


27.3 (ІП 


ОО000000000000000000000000000000000000Арасһер 
РНРОМУуЗО СОООООООО0О0О00000000000000000000000000000 
ОО0О0000000000000000000000000000000000000000 
АраспепПРНРИМУу5ОСЛОДОГО 


27.3.1 Apache 


0029000000000птоа mime[]mod negotiation[]ETL 
AddLanguage[]AddCharset] [ПППШШШШШШШШИШШИШШШИШШИШШП 
ПОСООООО0О000Арасперооооо00000000000000000000000000 
ОООООДО00000000000000000000000000000000000іпаех hem 
Псотрапу іпіо. піпПІООДООДООДО0О000О00000000000000000000 
ОООООДО000000000000000У/ебоОО0000000000000000000000 


ООАраспердрродордодорборордоооробороробддообороооробоод00000 x 
http://httpd.apache.org/ docs.2.0/content.negotiation.html ПППЦПЦПЦППАрасһеППП x 


00000000 


27.3.2 РНРППППП 


ПАрасперороДООДО000000000ОРНРОДОООООООО0ДОО0000000 
ОДОДОДО000000000000000000000000 
http://www.php.net/mbstring ПРНРООООДОООДОО0О0О0000000000 
IL Windowsi|[I i iphp.iniuphp mbstring.dll[ ПОП 


--enable-mbstring=LANG 


ПППКАМОПППИПППИП јарововеспроововововововобобооо 
ОО0000000000 


--enable-mbstring-all 


[jmbstring[ ПППРНРИПИНИНИНИЕНОВРИр «пІППИПИПИПИПИПІПІ 
ОДООО0О0000000000000000000400Д0п265сгіпа ПДОООО00000000 
РАРООООО00О 


ОО0О0000000000000000000000000000000000000000000 
РАРОООООООДОО0000О000000000000000000000000000000000 


27.3.3 MySQL 


ПООООО0О00О0000000МузОЗО0000000000000000000000 
МУ5ОСПОДО000000150-8859-1ПП00000000000000000000000 
ПООСООООООСОООООМУ5ОШТООООО00 
http://www.mysgl.com/doc/en/Localisation.html MySQL 


ПП 


27.4 ПОООООООООЦ 


ОДООДОО000000000000000000000000000000ОРНРОООДО000 
ООО0О0000000000000000000000000000000000000000000000 
0000000 


ППШПШШЦПППШПЦПИПШПИЦ\У/е РП ПШШИШШИПШИШИПИШШИИИИШШИИШП 
ОООО0000000000000030000 


° ПООООООДО00000000000000 
• ПОДООООДО0000000000000000 
° (ПП! 


00002 7.1000000000000000000000000 


000027.1 000000 


осо N б о + оо ñ = 


— — ل‎ — — k 
л + ©з о + Соң: 


16: 


П00000000000іпеіџае()00000000000000000000005еѕѕіоп_ѕёагё()0000000000000 


ПП 


<?php 


if ((!isset($ SESSION['lang'])) || (!isset($ GET['lang']))) í 


$ SESSION['lang'] = "еп"; 
$currLang = "еп"; 
) else ( 
$currLang = $ GET['lang']; 
$ SESSION[ Јапд | = $currLang; 


} 


switch($currLang) í 
са$е "еп": 
define( "СНАВЗЕТ" ,"150- 8859 - 1" ) ; 
define("LANGCODE", "еп"); 


ргеак; 
case "de": 
define("CHARSET","ISO-8859-1"); 
define ( "LANGCODE", "de"); 
break; 
case "1а": 
define( CHARSET", "UTF-8"); 
define("LANGCODE", "ја"); 
break; 
default: 
define( CHARSET^,"ISO-8859-1^"); 
define("LANGCODE", "еп"); 
break; 
} 
header( "Content-Type: text/html;charset=".CHARSET} ; 


header("Content-Language: ".LANGCODE); 


2» 


000027. 20р2г200080000000000000000000000 


ПППППППППаеяйпе lang.php[]lang. сігіпд5.рһрППППІПППвессіоп start(GL(IE | 


BPP.asssssnunananananamnanananamanananananananananananunananananananananananunananananananananananananunananananananananananunananananananananananananananananananananananananananananananananananananananananananananunanananananananananananananunanananananananananananananunanananananananananananananaunananana 


ОООО0000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000000000 
сип апа ПОДО0060000000 


010000 О5мієсирородддсєавероДоООООО0Д00000000СНАВЗЕТ 
LLANGCODET[I[I32[ILLIS 3000000000 0Content-ty pe[ ]JContent- 


languager[]H i p ILILILILI IILI I I 


П0000000аеппе Тапа.РиРДОДОДООУУеБОДОДОДООДО0О00000 
ОООО00000000000000000000000000000000000СНАВЗ5ЕТО 
(АМССОРЕДПООООООООООООООООООО0О00О00000000000000000 
ОООО0000МЕТАОООООООООООДОООООООО0000000000000000000 
ОО00000000000 


00002 7.2000000000000000000000000000000000000000 
ООО00000000000000МЕССОМЕ ТХТОДОООДОДООООООО 
ПСНООЅЕ ТХТПП 


00002 7.2 ПООО000 


1: <?рһр 

2; function defineStringsí) í 

З switch($ SESSION['lang']) í 

4: case "еп": 

5: define("WELCOME TXT","Welcome!"); 

6 define("CHOOSE TXT","Choose Language"); 
7 


break; 
9: case "de"; 
10: define("WELCOME TXT","Willkommen!"); 
Tas define("CHOOSE TXT","Sprache auswählen"); 
12: break; 
13: 
14: case "ja": 
15: define ("МЕ СОМЕ TXT","[unprintable characters]"); 
16: define("CHOOSE TXT","[unprintable characters]"); 
ЊЕ: ргеак; 
18: 
19: default: 
20: define{ "WELCOME TXT", Welcome!"); 
21: define { "CHOOSE TXT", "Choose Language"); 
22: ргеак; 
23: } 
24: 
25: ?> 


ОДО00000000апо, strings. ph pri npn nb nb p HO HOO 
ППППППУУе ППТ 00000000 000000Д0УМЕ2С2СОМЕ ТХТП 
CHOOSE _ТХТООО00000000000000009ейпе5ёгітоѕ() 00000000 
ОДОД0О000000000000000000000О5ум'еспООООО0000000000000 
ООО0О000000000000000000000000000 


ОООО0000000000000000000000000000000000000000000 
О0000000002 7.30000000000 


00002 7.3 00000000 


«?php 

session startí(); 

include ‘define lang.php'; 

include 'lang strings.php'; 
defineStringsí); 

2> 

<!DOCTYPE html» 

«html lang="<?php echo LANGCODE; ?>"> 

9: <head> 

10: <title><?php echo WELCOME TXT; ?></title> 


O Ја Ol T WN — 


11: «meta charset="<?php echo CHARSET; ?»" /> 

12: «body» 

13: «пі style="text-align: center;"><?php echo WELCOME TXT; ?></h1> 
14: «p style="text-align: center; font-weight: bold; "> 

15: <?php echo CHOOSE TXT; ?><br/><br/> 

16: «a href="<?php echo $ SERVER['PHP SELF']."?lang=en"; ?>"> 


17: «img 5Гс- еп flag.gif" alt-"English" /></a> 

18: «a href-"«?php echo $ SERVER['PHP SELF']."?1ang-de"; ?>"> 
19: <img src-'de flag.gif" alt="German" /></a> 

20: «a href-"«?php echo $ SERVER['PHP SELF']."?1ang-ja"; ?>"> 
21: «img src-"ja flag.gif" alt="Japanese"/></a> 

22: </р> 

23: «/body» 

24: </html> 


00000000002 7.3000000000000дейпе !апо.рпрП 
lang 5ігіп95.(рРИрООДОДОДОДООООООДОДОДОДООЗОДОДООО000000 
ООО00000000000000 


ПЭППППаеппевігіп ав ПОООД0000Д000000000000000008000 
10000110001300015000001600018000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООДО00000000000000000000001ап29000000005 ЕТО lang IOL 
О0000000000090002 7.1006000000000000000000000000000 


ОО0О0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000080000 
ОООО000000000000000020б0000000000000000000000000 


П0000000апо_ѕеіесёог.рпр0б00000\%№еор00000000000000 
0000000000000 2 /-2000000 





| = [s]. | x | 
C Welcome! 
€ Q | © http;//localhost/27/lang selector.php Il K aB 
Welcome! 
Choose Language 
qg, 





027-1 ПООД0000000 


ОО0000000000000000000%еісотерСһооѕе Language Il 
ОООО0000000000000000002 /-2000000000000090002 7-30 


| (= [e | X ! 
(С) Willkommen! 


= Q © http;//localhost/27/lang selector.php?lang-de 


к] ж B 
Willkommen! 
Sprache auswählen 
ы LZ 
027-2 [110000 
| = (а | ж ! 
С) вза 
= С! © http:;//localhost/27/lang selector.php?lang-ja К т зв 


NI LZ 
ZAS 


[27-3 000000 


ПОм/ерроророоововоооовововоооововововоооововооо 
ООО0ОО000000000000000000000000000000000000000000000 


ОО000000000000000000000000000000000000%еюоо0000000 
ООО0О00000000000000000000 


27.5 [jlgettext()||[ | III 


ОООДОО00000000000000000000000000000000000РНРОД 
деќехє)000006М0 gettext ППОДАРІОДОДОД 


ПО0006М0О gettext т I JLI IILI 
http://www.gnu.org/software/gettext/ gettext.htm [] 


Продекех и ППОРНРОДООООООООООДОДОО0ОбО0О0000000000000 
ПППППППРоедПППһер://муум.роесат.сога/ ПОООООООООООООО 
ООД0000000000000000000000000000000017ап5ітех 
[Ihttps://www.transifex.net/ []]]Get Localization 
[]http://www.getlocalization.com/ ОДОООДДО00000000000000 
ПОМеюоо00000000000000000009еёех 00000 


ПППРНР Manual[]http://www.php.net/gettext 0000 
gettext[ [| ettext[ ПОРНРОДОООООО0ОДО0О0О0О000О0 


• [[[]putenv()[]LC ALL епмігоптеп [000000000 

• Пе оса!е ОПИС АПТППППИПИ 
http://www.php.net/setlocale ПП 

e [I[]bindtextdomain  ОПОДООДО0О00ДОД00000000000000000 


00000000000Омммммм. my demain сот ООД0О0000 
http://www.php.net/Bindtextdomain ПД 


e ДПДеехкдотаїп()000дебсехіДОДО0О00000 
http://www.php.net/ textdomain ПП 

ГІП tIgettext[] some string"[]|]]] some string"L]LDLLDLIL] 
ПППППоевехе ПДОДООД000000000000007 Welcome" 000000 
П"МКоптеп!"ДОООСОООООООООООООООООООООО00 
[]Willkommen'!"[] 


echo ("Welcome"); 
ООООДО000000000000000000000000000000000000000000 


О0000000000П9есехс  ОООО0О0000000000000000000000000 
ОО000000000000000 


27.6 || 


ООО0О0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ООО000000000000000000 


ООО0О0000000000000000000000000000000000000000000 
ОДО000УУевороордооодоророробо0 


ОО0О0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ОДООДОО000000000000ОРНРПдейех і ПІ 


27.7 Q&A 


ОПОРАРОДООООДООООО00000000 


АОООДОО0000000000Опиутобег їогтаё)Оааќе() 00000000 


даёе()О00000000000000000000000000000000000000000000 
MM-DD-YYYY, О0-ММ-ҮҮҮҮр000питобег Ғогтаї()0000000000 


ПОДОДОДОД0О00О0000000000000000 
http://www.php.net/number format ПРНРООДОООДОДОО 


27.8 [I 


ОООООД00000000000000000000000000000000000000 


ӨШ 


1ОДО00000000000000000000 
2 ВО000000000000000000000000000 


ЗОПОДОД00000000000000000000000000000 


ИЦ 


100000000000000000 
20Д000000000Сопіеп--| апдиадердСопеепі-ТурегП 


ЗОДПООО 000 00000000000000000000000000 


ӨШ 


Ш0бвоод!е ТгапвіагеТ пООДОДОДООООО0О000О00О000000000 
00000000000“ МеІісоте!" 00 


2 ПОООДО0000000000000000000000000000000000000000 
000000 


028] ПИХМІ 


00000000 


ОДОД00000Х MET TEETCTETE] 
° ГПШПООМГППРНРГППХМЫІ 
• [| ISimpleXMLII | IPHP|I | JXMLI | 


• ПОД SONDOU 


ОДООООООРНРеДОХМЕДОДЗОМОДООООООООДООО0О0000000000 
ООООО000000000000000000Х МЕРООООООДОРНРДХ МЕООДОДО 
ОО0О015О0МПОООООООООООООО0О00000000000000000 


28.1 [| j XML 


ХМОДОДОООДОО00О00000000ЕЄхгепзібіе Markup 
гапдиадедрПООООПО000000000000000ХМОДНТМЕООДОДОООООО 
ООООО000000000000000000ХМЕРДОДОООООООООД000НТМЕПО 
ОО0О00000000000000000000000000000000000000 


28.1.1 ПІХМЦОООГ 


ХМЕПОООООООООО0О0ООО0О0000000000ХМЕООООД0О0000000 
00000000 


ОО000000000000000 


<?xml мегѕіоп="1.@" 2» 
<!-- Sample XML document --> 


ПООООООООООвОХ МАДОООООООООООООООООООООООООООООО 
ООО00000Х МЕДОДООДОДОООДОДО00О0000000000000ВооКк5 0000 
<Воокѕ> </Воокѕ> 000000000 


<Books> 


ОО0О0000000000000000000000000000000000000000000 
ОДОД0О000000000000000000000 Tree ЦА и по Publishing Infor] 
ООО0ОО00000000000000000000000000000000000000000000 
ОДОД0О0000000000000000000000х PublishingInfo> 1000000 
ПП 


«PublishingInfo- 
<PublisherName>Sams Publishing«s/PublisherName- 
«PublisherCity»Indianapolis«s/PublisherCity- 
«PublishedYear22812«/PublishedYear- 
</PublishingInfo> 


ОД00000000000000бо0кз5.хпліД0Д00000 


<?xml versionz"'1.0" ?> 
<!--Samole XML document --> 
<Books> 
<Воок> 
<Title>A Very Good Book</Title> 
«Author»Jane Doe</Author> 
«PublishingInfo» 
<PublisherName=Sams Publishings/PublisherName- 
«PublisherCity-Indianapoliss/PublisherCity- 
<PublishedYear=2012</PublishedYear> 
</PublishingInfa> 
</Book> 
</Books> 


ОДОД000ХМЕДОООООООО000 


° ХМІДДО000000 « Book» [] «book 100000000 
° ПООХМЕООДДОООООДОХ МЕБДДООООО000000000000 


Цбоок5. хппПІДОДООД0О0О000000000УУебОДОООООДОДОДОДОО 
ОДБОДО00000000000000000000000ХМО00О 


28.1.2 ||ШІППХМІПРНР 


ОДОД00000000000000 0000000000" 00000000000000000 
ОООД00000000000000ХМЕОДОООООО0О0ОООО0000000000000000 
ПП 


ОООО0000ХМЕеДДОООДОО0ОООООО00000000000000000000000 
ОООО000000ХМЕДООООООООООООДОО0000000000000000000000 
ПХ МЕБОДДООООООО0О0000000000000ХМЕДОООООО0000000000000 
ОООО0000000000000000000 


ООООО0000000000000000ХМЕДОДООДО0РОМОО 
зітріехХМІДОДОДОДОООДОДО0000Х МО ОДООбОДОДОДО0О0000000 
ОДООООО000000000000000005іпріехм(ДООРОмМородроОО 
ОООО00000000000000000000000000000000000ХМЕООД0ОО0О 
ООООО0000000000000000000000000000000000000000000000 
ОООО000000000000000000000000000000000000 


28.2 (|ЦПБОМІІЦРНРГГЦХМІ. 


ПОРНР 400000М ХМОДООДОРАРОДОООООРНР 5000000000 
ОООО00ОРНРОДОДОООООРОМОДДООДОООООООО0О О0О0000000000 
ULL] 


ромродородрорроситепі Object Моде п ДОДРрОомДзоОП 
http://www.w3.org/TR/DOM-Level-2-Core/core.html [] 


РООМПООООООДОД0ОДОРОМ АРІДПООООООХМЕДООО0000000 
ОРОМОбОРомрОоситепі-»Їоад ОПООООООДОО000000000р0М 
ОО000000МПООоО000000000омПр0000000000028.1000ромП 
ОО00000МПО0000000000000 


000028.1 ППрРОМПЦППИХМЫШП 


1: <?php 

2: $dom = new DomDocument; 

3: $dom->load("books.xm1") ; 

4: 

5: foreach ($dom->documentElement->childNodes as $books) 4 

6: if (($books->nodeType == 1) && {$books->nodeName == "Воок")) 4 

7: 

B: foreach ($books->childNodes ав $theBook) í 

9: if (($theBook->nodeType == 1) 8% 

10: {$theBook->nodeName == "Title"}) í 

11: $theBookTitle = $theBook-»textContent; 

12: } 

13: 

14: if (($theBook->nodeType == 1) && 

155 ($theBook->nodeName == "Author")) í 

16: $theBookAuthor = $theBook->textContent; 

I7: } 

18: 

19: if (($theBook->nodeType == 1) 88 

20: ($theBook-»nodeName == "PublishingInfo")) 4 

21 

22: foreach ($theBook->childNodes as $thePublishingInfo) í 
23: if (($thePublishingInfo->nodeType == 1) 88 

24: ($thePublishingInfo-»nodeName == "PublisherName")) í 
25: $theBookPublisher = $thePublishingInfo->textContent; 
26: } 

27: 

28: if (($thePublishingInfa->nodeType == 1) 84 

29: ($thePublishingInfo-»nodeName == "PublishedYear")) 4 
30: $theBookPublishedYear = 

311 $thePublishingInfo->textContent; 

ја. } 

33: } 

34: } 

35: } 

36: 

37: echo " 

38: <p><em>" .$theBookTitle. "</ет> 

39: by ".$theBookAuthor. "<br/> 

40: published by ".$theBookPublisher." in ".$theBookPublishedYear."«/p»"; 
41 

42: unset($theBookTitle); 

43: unset($theBookAuthor) ; 

44: unset($theBookPublisher); 

45: unset($theBookPublishedYear); 

46: ) 

47: } 

48: ?> 


ППОПППППППИПООМПИПИПЗППОоокв. хпіДОД0О000000000 
ООО0000000000000000000000000$аото00050000000000000 


О00000000000000000%6оокѕ$П0000 


Lern Воок"ПОДОООООД0000000000О« Beo K » 
«/Воок»ПдуДОбоок5 xml pin niniininmnibmbimms nm i dr 
ОДОД00005певоок/0П000000090001200001400012 70000000 
Про“ Тійе"П"Ацепог" ООООДОО000000009ЕпевВооктікіеп 
$theBookAuthorQU000000000 


ПІ9П00000001#0000000000000000*Риюііѕһіт9 Info [II II 
[IL <PublishingiInfo></PublishingInfo> 0000000000000000 
ОООО00000000000000000000002200000000000000000 
$thePublishinginfo 000000002 30002 60000 2 80003 200#0000 
HtlEIE]/PublisherName"[]"PublishedYear" UBBEIEBIEIEIEIEIEETETETET ETE] 
$theBookPublisher[|/$theBookPublishedYear 1000000 


ПО80000000003500000037000400000005 ћеВооктше 
$theBookAuthor[]$theBookPublisher[]|$theBookPublishedYear 
бробододродорорободородордоробораго0)рр45000000000000 
ПО00000*Воок” 00 


П0000000009отехатріе.рћро000000№еоро0000000000 
ООМеопо000000000000028-1000000 


[5] localhost/28/domexample. 
= С! | © http://localhost/28/domexample.php Ki м ~ 


A Fery Good Book by Jane Doe 
published by Sams Publishing m 2012 





An Academic Book by Anne Smith 
published by University of California Press in 2011 


зоте Fluff Fiction by Jimbo Jones 
published by Fluffy Press in 2009 


[28-1 ПОРОМОДОДОДОДОД 


ОПООРНРОДЗОДДООМДОДДЗОДООДООДбОДОДОХМЕДОДОООДОДО 
LIEIEIE HEIL ]htE p ://ww w. ph p.net/dom ПРНАНРОПО 


О00000000000006оокѕ.хті000000005ітріехмі 000000 
00000 


28.3 || ипргехм ПРНРЦЦОХМС 


SimpleXML[]PHP 500000000000000000000000000000000 
ПОООООООООРАРООООООООООО ОХ МЕОДООООДО0000000000700 
00000000 


ПООМЦПЦПШИШПШИШИПШИШШШИШШИИИШПӘ!трехХМ ETEETEEIDIEIEIEIET LI 
ОУО000005іпріехми ОХ МІЕОДОДОЗОЗООООДОДОДО00000000 
ОО000000000000000000000000005тріехті Іоаа_#іе()000000 
ООО000000000000000000 


$object with data = simplexml load file("somefile.xml"); 


0000028.2000000000000005іпріехм'е рродроророооообО 
0000 


000028.2  005іпріехмі 100000 


: <?php 

: $theData = simplexml load file("books.xml"); 
: echo "<рге>"; 

: print г(%%һебата); 

: echo "</pre>"; 

. 2> 


Oar GO го = 


0020000simple_load_file()ĝbooks.xmi 0000000000 
$thebata[JLEEDI EAD UD Uerimt г()000000000000000000000000 
<pre> </pre> DBBUBDCL] 


ППИПИПППППәітріехіті dump. php jd m Webb I III) 
О00000УУевбрОООООО000000028-2000000 


[2] localhost/28/simplexml du 
= Q ©) Rhttp://localhost/28/simplexml_dump.php Ki м ~ 


dimpleXMLElement Object 
( 
[Book] => Array 
| 
[0] => SimpleXMLElement Object 
Ї 
[Title] => A Very Good Book 
[Author] => Jane Doe 
[FublishingInfo] => SaimpleEMLElement Object 
( 
[PublisherHame] => dams Publishing 
{PublisherCity] => Indianapolis 
[EublishedYezr] => 2012 


1 


[1] => JimpleXMLElement Object 
( 

[Title] => Ап Academic EBook 

(Author) => Anne Hmith 

[Publishinglnfo] => УлтрјекГЕјетепњ Object 

[ 

[PublizsherHame] => University of California Press 
[PublisherCity] => Berkeley 
[EublishedYezar] => 2011 


1 


[2] => BSimpleXMLElement Object 
( 

[Title] => Hume Fluff Fiction 

[Author] => Jimbo Jones 

[PublishingInfo] => SimpleXMLElement Object 

( 

[PublisherHame] => Fluffy Press 
[PublisherCity] => Нем York 
[EubliszhedYezr] => 2009 


028-2 QUUUSimplexMLOQUUU 


ОО0О0000000000000000000000000000000000000000000 
О00000005іпріехті айпар.риРОДОДОООО00000 


[0] => SimpleXMLElement Object 


( 
[Title] => A Very Good Book 
[Author] -» Jane Doe 


[PublishingInfo] => SimpleXMLElement Object 
( 
[PublisherName] => Sams Publishing 
[PublisherCity] => Indianapolis 
[PublishedYear] => 2012 


ООО0000000000000 


$theData->Book 


ОО000000000000000 


e StheData--Book-» Title Тог the Title 

е $theData->Book->Author for the Author 

e $theData->Book->PublishingInfo->PublisherName for 
the Publisher Name 

е $theData->Book->PublishingInfo->PublisherCity for the 
Publisher City 

е $theData->Book->PublishingInfo->PublishedYear for the 
Published Year 


ОООО00000000000000000000000000000000000001028.3 
000000 


000028.3 QOSimplexXMLOQOOXMLGY 


со + Ф Q + ом = 


<?php 
$theData = simplexml load file("books.xml"); 


foreach($theData->Book as $theBook) { 


$theBookTitle = $theBook->Title; 

$theBookAuthor = $theBook->Author; 

$theBookPublisher = $theBook->PublishingInfo->PublisherName; 
$theBookPublisherCity = $theBook->PublishingInfo->Publishercity; 
$theBookPublishedYear = $theBook ->PublishingInfo->PublishedyYear; 


echo " 

<p><em>".$theBookTitle."</em> 

by ",.$theBookAuthor."<br/> 

published by ".$theBookPublisher." (".$theBookPublisherCity.")} 
іп ".$theBookPublishedYear. "</p>"; 


unset ($theBookTitle) ; 
unset ($theBookAuthor) ; 


unset (S$theBookPublisher} ; 
unset ($theBookPublishedYear) ; 


002000О5іпаріе load #е()Пброокѕ.хті000000000 
ѕїћераѓаЦ000004000$%ћераѓа-> Воо КИДОДОООООО00000000 
00$ ћеВоок00000050009000000000000$%ћеВоок00000000 
00002200015000002 /0)0020000000000000000000 


ООД00000005імпріехтіехатріе.риродоро000Умев О00000 
ОД00000У/ерро000000000000289-3000000 


= | mem 
[5] lacalhost/28/simplexmlexa 
= С! | © http://localhost/28/simplexmlexample.php Ki м ~ 


А Very Good Book by Jane Doe 


published by Sams Publishing Indianap olt У in 2012 





An Academic Book by Anne Smith 
published by University of California Press (Berkeley) m 2011 


Some Fluff Fiction by Jimbo Jones 
published by Fluffy Press (New York) m 2009 


028-3  005іпріеХмМЕДДОДОД0000 


О000000000000028.1000000000000005іпріехмидррород 
ОДОД00РОМОрооддрбОрО00000000000 


ОДООДОРНРО5ітріеХм' ДрОродорДоДрдП 
http://www.php.net/simplexm!l ПРНРИПП 


28.4 []]SON 


ІБОМППамассгіре Object МобапопПамасстр ООООООООО 
ПОООООООВЕХ МЕРОООООДОО0ДДОО0О0О0000000000000000004Ц)5ОМ 
ОДООООДД000000000000АРІООДОООДОДОООДОДООХ МЕДООООДО 
OOL 


ОШ5ОМПОДОООД/ ООООООООО00О0О000000000000000000 
ОД0000000000000000000б00к5. хпліДООДОДО ОД15ОМОДОДСОО 
000000 


{ 
"реек": | 
1 
"title":"A Very Good Book", 
"author": Jane Doe", 
"publisher name":"Sams Publishing", 
"publisher city":"Indianapolis", 
"publisher уваг" : "2012" 
} 
| 
l 
ПООСООООООСООООООО5ОМОО00000000028.4000 
000028.4 JSON LI] 
1: { 
2: "book" : [ 
3: 
4: "title":"A Very Good Book", 
5: "author" : "Jane Doe", 
6: "publisher name":"Sams Publishing", 
7: "publisher_city":"Indianapolis", 
8: "publisher уеаг" : "2012" 
9: }, 
10: { 
11: "title":"An Academic Book", 
12: "author" : "Anne Smith", 
13: "publisher name":"University of California Press", 
14: "publisher city':"Berkeley", 
15: "publisher year":"2011" 
16: }, 
17: 
18: "title"':"Some Fluff Fiction", 
19: "author":"Jimbo Jones", 
20: "publisher name":"Fluffy Press", 
“ЗЕ "publisher city":"New York", 
221 "publisher уеаг" : "2009" 
ed: } 
24: ] 


ПООООЈ5 о МООООООООћр мм, ј5оп.огд ОДОДО0)5ОМПП 
ПО0000000050МО00000пр://јѕоп.рагѕег.опііпе.їг/ ОООООООО 
ОО0000000000000 


ООО0Д0)5ОМДОДОСОДОРНРІ)5оп deced eO Tii i IILI I I 
ООООО000000000000005іппріехм' 0)00000000000028.5000000 
ОДООО000000)5О0МПОДОДООО0000000000000 


000028.5 = ОООООЈОМОО 


: <?рһр 

: $theData = file get contents("books.txt"); 
: echo "<pre>"; 

: print r(json decode($theData)); 

: echo "</pre>"; 

. 2> 


о UO ој — 


ПӘППППе де сопёепё()1П0оокѕ.іх#100000028.400 
ЈЅОМОП000000000000000000%һћерағарр00000400югтё го00 
ОО0000000050МО0000000000000000<рге> </pre> 0100000 


ОО00000Дівоп, дчпар.РЕРДОДОДОООУУеБОДОДОДОДОДОДО 
\Ме ПОД00000000000000028-000000 


L= | l >. 


[5] localhost/28/]son dump.p! 


e С! | © http;//localhost/28/json dump.php |] к ~ 


| ъ 


stdClass Object 
| 
[book] => Array 
( 
[0] => stdClass Object 
( 
[title] => А Very Good Book 
[author] => Jane Doe 
[publisher name] => Sams Publishing 
[publisher city] => Indianapolis 
[publisher year] => 2012 
) 


[1] => stdClass Object 
| 
[title] => Ап Academic Book 
[author] => Аппе Smith 
[publisher name] => University ої California Press 
[publisher city] => Berkeley 
[publisher year] => 2011 


111 


) 
[2] => stdClass Object 

( 
[title] => Some Fluff Fiction 
[author] => Jimbo Jones 
[publisher name] => Fluffy Press 
[publisher city] => New York 
[publisher year] => 2005 


[28-4 [EJSONIT] 
ООО000000000000000000000000000000 


e $theData->book->title for the Title 

e $theData->book->author for the Author 

е $theData->book->publisher name for the Publisher 
Name 


е $theData->book->publisher city Тог the Publisher City 
е $theData->book->publisher year for the Published Year 


О000000000050МО00000000000АРІ00000009КЕ 00000 
ПАРІДОДООО 6 оо41епрАРІДДООДОДОДУООАРІОООООО01.000ч00 
ОООДОО000РНРОД 


http://ajax.googleapis.com/ajax/services/search/web?v-1.0&q-PHP 


0000028.50020000000000000000 
json google аитр.рһр000000000%еюп0000000000 


$theData = file get contents("http://ajax.googleapis.com/ajax/services/ 
search/web?v21.0&dg-PHP"); 


ПОВЕАА/е о0000000000000000028-5000000 





а localhost/28/json google. 
< Q | © http://localhost/28/json_google_dump.phy I] AK X 


stdClass Object 
( 
[responseData] => stdClass Object 


[results] => Array 
( 
[0] => stdClass Object 


[GsearchResultClass] => GwebSearch 

[unescapedUrl] => http://www.php.net/ 

[url] => http://www.php.net/ 

[visibleUrl] => www.php.net 

[cacheUrl] => http://www.google.com/search?q-cache:cdtJOE-OieIJ:www.php.net 

[title] => PHP: Hypertext Preprocessor 

[titleNoFormatting] => PHP: Hypertext Preprocessor 

[content] => Server-side HTML embedded scripting language. It provides web developers with a 


(1) => stdClass Object 


[GsearchResultClass] => GwebSearch 

[unescapedUrl] => http://php.net/manual/en/index.php 

[url] => http://php.net/manual/en/index.php 

[visibleUrl] => php.net 

[cacheUrl] => http://www.google.com/search?q-cache:WIwFqge3yfIsJ:php.net 

[title] => PHP: PHP Manual - Manual 

[titleNoFormatting] => PHP: PHP Manual - Manual 

[content] => Complete and hyperlinked manual documents and explains all... 
) 


[2] => stdClass Object 
( 


[GsearchResultClass] => GwebSearch 

[unescapedUrl] => http://en.wikipedia.org/wiki/PHP 
[url] => http://en.wikipedia.org/wiki/PHP 
[visibleUrl] => en.wikipedia.org 


Г-аскә!7-11 => +: / Уча е0 о -ғәе/заазе-кқ?О,/т--а-ықе.-.СМр MITT T'an о ззузЗтьасСза are 
I" 








[]28-5 [JGoogle[][]HJSON[IL 


ПППППППБОМЦПППИПИППППИРНРПП)воп decede OTi] 
ОООО0000000000000000000000000000000000000000000000 
ПППППАРІПППППИПИПИПИПИРгодгаттаБеу/еоі ПГ 


http://www.programmableweb.com/ [| 


28.5 || 


ОООООДО000000000ХМЕПОРОМОПО5іпріе Х МІПД|5ОМОРНР 
ПОООООО00000000000000000000000000000000000хм1)50МП 
ПИВВОВОВОВОВООРАРООХ МЕ ЈЉОМОООООПООООПОХМ ЦЈРНРОЦ 
ПОООООЦАЈАХ (Asynchronous JavaScript and ХМІДПП 
Івмазспір ЦХМІЛПИПППИРНРППИПИИХМИ JS ONEITIEIBBIDIEIEI DICIT TL I 
ПЦ 


28.6 ОФА 


ОПООМУу5ОЄПОООООООООООО0000000000000Х M COOOL 
HOL 


АПХМЕДДООООООООООО00ООО000000000000000000000Х ML | 
ОООО000000000000000000ХМЕДДОООО0О0000000Му 50800000 
ОООООО000000000000000000МУу5ОСПООО00000000000000 
ХМЕБООООО0ОДО00000000 


ОТПООООООО0000000000000000ѕоМПІ 


АПО00000Ј50МО00000000)ѕоп_епсоде()050000000000000 
0000000050 МООООбА р //ww w.php.net/json encode 00000 
ПО 


28.7 ПШ 


ООООО000000000000000000000000000000000000000 


ӨШ 


ALIETICIEIEJMLLIEIDOIDIEIDICILILICÓLI 


2 HEIBDEIEIDICIX МЕДОООООООДРВОМОДОДОП 


$dom - new DomDocument; 


30000000000000ппу хпл0О0000000000005 my Data ] 
SimpleXML IEEE 


ИЦ 


11<?хті мег5іоп "1.0" 


2 ДО000000000000здо0промоорородобо III] 


$dom-»1oadí("books.xml"); 


30$myData = simplexml load Еіе("плу.хплі"); 


ӨШ 


1. 0О0000000)5О0МООООО00000000000000000000028.10000 
028.З3000000 


2 ПО00000000000000000000000000000000000)50Мҹ0000 
ООООО0000000000000000000000000000000000000000П00АРІО 


1290 
1300 
1310 
1320 


01330 


Hegu 00000 


Арасперпроро000 
ПОВОСОЕМ еб 000 
ПОПООМУЗОЁ 

ПППП 


00000000 


0290 Араспердрро0000 


ОО00000000 


ПООООДАраєверооороодоороооброрборо000 
ООДООО0Арасєверор000 

ОДООАрасперпоо 

ПОО0Арасһће 0000000000000 
[0000000000000000Р000000000000000 
00000006 М500000 

000000000000000 


ОООДО0000000000А расперодрододордорововорородродророп 
ОТРООДОДОВМ5ОДОО00000УУеБДБОООДООДОО0О0ОО0ООДОДО000000000 
ООО000000000000000000 


29.1 [JI 


ОООДО000000000000000000000007 ИШИП 000000000000 
ОООО0О00000000000000000Араспедрооо000000 


29.1.1 [ID 


ООДООО00000000А раєперордродододорововоророродороп 
ОО0000000000 


Араспероррооб0Д000000000000000000000000000000000 
О0000000МеБоо00000000000000000000000000000000 


ApachelUUUUUMuIti-Processing Module[]MPMT[JELCLLICLILLI 
О5ЗОДОДО000О000000000000000000000000Ц-їпаехОДОД000П 
П/ргос/5уз/кегле Лћгеаа5-глах ППОПОМА_ТАБК5УПИОПОООООООО 
ОДО00000000 


# cat /proc/sys/kernel/threads-max 


ОО000000000000000 


# echo value > /proc/sys/kernel/threads-max 


ПИПпчХППППИПИППОМИПИПИПИППИПИПИППППИПИПИППОЭПІ 
ОО00000000 


[]Solaris[ НОД000000/еєс/вувсепаДОООООООООДОДОДО0000000 
О00000000000090000000пах, пргосѕ 100000000000 
пахиргос ПОДО0О00000000000 


2100000 


ПОСОООООООООО0О000О0ОѕоскеєООО00000000000000000000 
ООООО5ПО000000000000000000000000000У/еббор00000000 
ОООООДО00000000000000000 пох ОДОДО0000000 
П/ргос/5у5/15/Пе-тлахП По! а по ПППОООООО /е с/5узкега ПП 
гіпо _та_гтахрррооооооооооо0оОО 


[]http://httpd.apache.org/docs/2.2/vhosts/fd-limits.html [| 
ИШШШШШЦИП 


30000000 


АрасһерОО0000000000000000000000000000000000000 
ООООО0О00000С51000000000000000000ОРНРООООООО0000000 


ОООО0О00000000000000РН Р0000000000000000000000000000000000000000 
ОДПОООООО00000000РНРООООООДООООООООООООО0О00000000000000000 | 


ПОПАраспепппп ПА ра. сопіОДОДУ МА ХОДОДОДОСОСООДО 
ПП 


° КІПТІЕСРІ)-ПИПИПИППППИПИППОРОПИПИППППИПИПИППІП 
UUUUUmeax ПП ИИ! 
ООО0О00000000000000000 

° КитиМет—— ДОДАВ СіптЕСРООДООДОООДОДОД0бО0О00000000 
ОО000000000 


° ВЦіпї  МРгос- -- ПОПА пі СРОООДОДООДОДОООО0О0000 
ОЗОДОО00000000000000000000000000 


29.1.2 ПП ПП0Арасћте [|| 
ОДОДОД0000000Араспероб 
10000000 


ООО0ОО0000000000000000000000000000000000000000000 
О000000000Прег-їгессогу  ОООООООД0О0О0О00000000000 


• 0000---ПУМІХЮДОДООвуплбоїіс пакуДезупо по КОООО0000 
ОДОД0О00000009МІХДІпОООООООДООб0О00000000000000 
ПП 


Options[UUUUUUUUUUFoOIlowSym Links|] 
5утпК5!ТОуупегМаїсһППЦШШШПАрасһе[ПППШШШШШШШИШШИШИП 
ОООООДО000000000000000000УУебороообобд00000000000000 
ПОСООООООООООМУеоро0000000000000Араспероооо00000000 
ПО00000005утипкѕ!#ОмпегМаїсп000000000000000000000 
ПООО0000000000000 


ОООО0000000000000000000000000000000000000000000 
ОДОДОО00000000000000Орбїоп50--РоПом5ут Lin ks ПОДОДОДО 
symLinkslfOwnerMatch ОПООООДОДОДОДОООО00О00О0000000000 


е рег-агескогудоро——000300000О0ОООбре-аескогудрроо 
00000000. ћеассез000000000000000000О0О0О0ооо0о0ооооооОо 


ОООООДО00000000Араспедроододбобороббооророррорр00000 
ООООО00000000000000000рег-атгесёогудоо000000000000 
AllowOverride поперО000000000000000.һассеѕ5$00000000 
ИПШПШШШШШЦИП 


• 1000——Арасһеро00000000000000000000000000000000 
ОО00000000000000000000Арасһерпопо00000000000000 
ООО0О0000000000000000000000000000000000000000000 
ОООО00000000А pa ch er lbi n p i i2 700000 

e 00000----ООДООО000О0Арасперодрородорововоророрро0000 
00005согеВоагағіерпоо000000000000000000000000000 
ОДООДОО0000000000000КАМОООООООООВАМОДООООДОДОД 
ОДООДОО0000000000000000ААМОООООООО0ОО00000 


210000008 
ОДОООД000Арасверроророоо0 


е HostnameLookups——[]HostnameLookups[][][Jon[jdouble 
ОООООД00000000Араспероодроо МП00000000000000000 
ОООООДО00000000000000000000б0000000000000000000 
ПООО000000000000000000000000000 

• 0000----АрасрердО ДОД ООООДАраспердооородоророод 
ООООДОДОД00000000й166р.//пієраї. .a pache.org/docs- 


2.2/misc/perf-tuning.htm!l ПІ! 

e mod 5гаїц5----ОДОДО0000000000000000000000Араспеп 
П0000000000000000000000Ехеепаегазга и ПППойПо ДЦ 
LLU 


29.2 ЦАрасһеВепсһ [||| 


ООО0О000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОДООДО00000000000001пеегпеєдоООО000000000000000000000 
ООООО00000000000000000000000000000 


ПООООДОД000000000000000000000000000Арасперрддоод 
ППИПППППППППИПППАрасһеВепсһПарПППШПАрасһеПППП 
П/Біп ПП 


ООООО00000000009820О000000000000000000200000000 
39000000 Омууум.ехаптріе согл 00000 10000 


# /usr/local/apache2/bin/ab -n 10900 -c 18 httpi//www.qgoogle.com/ 


ородробав обобобоборопоподобобоборопооодорбобу а поподоообобобопо0. 
00000 | 


00000000 


This is ApacheBench, Version 2.3 <$Revision: 655654 %> 
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ 
Licensed to The Apache Software Foundation, http://www.apache.org/ 


Benchmarking www.google.com (be patient) 
Completed 100 requests 
Completed 200 requests 
Completed 300 requests 
Completed 400 requests 
Completed 500 requests 
Completed 600 requests 
Completed 700 requests 
Completed 800 requests 
Completed 900 requests 
Finished 1000 requests 


Server Software: gws 

Server Hostname: www.google.com 
Server Port: 89 

Document Path: / 

Document Length: 11955 bytes 
Concurrency Level: 18 

Time taken for tests: 50.751 seconds 
Complete requests: 1000 

Failed requests: 669 


(Connect: 0, Receive: 0, Length: 669, Exceptions: 0) 
Write errors: @ 


Total transferred: 12710814 bytes 

HTML transferred: 11974814 bytes 

Requests per second: 19.70 [#/sec] (mean) 

Time per request: 507.515 - (mean) 

Time per request: 50.751 - (mean, across all concurrent requests) 
Transfer rate: 244.58 [Kbytes/sec] received 


Connection Times (ms) 


min mean[-*/-sd] median max 


Connect: 31 50 11.3 46 179 
Processing: 88 454 53.8 449 893 
Waiting: 84 285 119.0 282 694 
Total: 136 504 56.5 499 850 


Percentage of the requests served within a certain time (ms) 
50% 499 


66% 512 
19% 521 
89% 527 
99% 540 
95% 564 


Q A9: 711 


99% 754 
100% 850 (longest request) 
ПОО000001піегпеєо000000000000000000000000000000 
ООООО000000000000000000000000000000000000000000000 


ОДООДО00000000000000000000000000000001000000000 


О ОООО ООЦОНООНО ООО ОСОНУ 


29.3 00000 


ОО000000000000000Арасперобо0000000000000000000 


29.3.1 MLL 


ООООО0000000000000000000000000000000000000000000 
П000Араспер0000000000000000000000000000000000000 
mod file сасһеу00000ММарғерооо0000000000000000000 
ОДОООО000000000000Араспе 2.хр))00000Сасперіеррордоооро00 
ООООО00000000000000000000000000000000000000000 


29.3.2 [| 
ОО000000000000000000000000000000000000 


• ПООООДОООООДООО0000000000Н T ТРОООООООООО0О000000000 

e ОООДООО000000000000000тоа rewrtiterj iii] 

• ПОДООООДО0О0О00000000000000000000000000000000000 
ООД000Оіпадез.ехатріе сот JI m m i i t] 


29.3.3 || 


ООО0О00000000000000000000000000000000000000000 
HT ТРУОООООДОО0ООООО000000000000000000000000000000000 
Отодо ПООДОДО0О000000000000000 


ПППИППИППППАрасһе 2.xtmod саспероррорДоОДОДООО0000000 
ООООО0000000000000000000000000000000000000000000000 
00000 


Apache 2.4ПО000000000А распердрорб0Д0000000000000000000000000 
http://httpd.apache.org/docs/2.4/caching.html ПАрасһе Caching Guide|] 


29.3.4 [| II] 


ОДООО0О00000000000000000000000000000000000УУебі/ 0 
ООО0О00000000000000000000000000000000000 


° ПП 

° ШШШ 

° (ПП 

e ПОДОДОНТМЕДДОДОООДО 

° UUmod_deflate QA МІД О СРОДДОДОДОДООД0000000000 
ООО0000000000000000000000000000 


29.3.5 (ІП! 


НТТР 1.1000000000000000Н T TP 1.0ЦЦПКеер-а!уе[ПППШПП 
ПОКеерАнуе Timeout ПП LIL ILI ППТ 
ОО000000000000000000000000000000000000000000Арасће 
ОО0О000000000000000000000 


29.4 [|] 


б0000О0епіат of ѕегмісеПроѕ5П10000000000000%еюо0000 
[00000000000000000029$00000000000000000000000000000 
ОО0О0000000000000000000000000000000У/е6000000000000 
[0000000000000000000000000000000 


ООДО0000000000000000000000000000000000000000000 
ООООООДОб0000З0000000000000 1 іппебонмедоодододоодозооооо 
ПППППППППППППЫ тЕесциевеВоауПитивЕесичиевіҒеіса<П 
LimitRequestFieldSize[]LimitRequestLine[] 
LimitXMLRequestBody|{] 


LIL IWebi i iWebi роророророрууер ророзодрорсороодДоп 
LLILILILI LIL LiWebiI[ IILI IILI L CE nter e tt TE iWeb[i[ III II III IL 
ОО000000000000000000000%ебоооооо0000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ПП 


Ор000У/евроородоор000Огобоє -х Д)ОДОДОДОДОДДУМУевО 
О00УУевродроОбОСОДОО000000000000000 


http://www.robotstxt.org/ ПППППЦПЦПЦПИППЦПЦгоОрої5$.їх[ПППП 
МеБоороооовоооооооовоооооооооооооооовоооооооовооо 


29.5 00000 


Поомеврроооововоооовововоововобомеоооововоооо 
ОДОД00000000УУеОДО00001пеегпеєроо0О000000000000000 
ОО00000000000000000000000000Арасһерооо000000000000 
ПОВЕНЕТРЦОВИВОНОВЕРИООВОВОВОВОВОВОВОВЕТРОВОВОВОВОВИ 
ОООО0000000001РООО 


Web ІІ ПППППаотаіп name server зузкеглрм5 ПОПОЦ 
ОДО0ТРООООДОООО0ДОО000000000000 


° 000----ОО000000000000001РООООООДОТРОДОДОДП 

“/ППП--ППИПИПИППИРПППИИИПИПАрасһеП IDE D Web mir] 
ОДОО0О000000000000000000000У/еБордоооо0000 

° 000—-0000000000000001РО0000000000000ноѕ 00000 
О0000%Уеюро00000000000000 


О000000000000000МрО000000000000)О0000001РО00000000000000000 | 
ОБМ5ПО00000000000000000000000000М5000000000000000У/еБ 000000М5000 
ООООО0О0000000000000000УмеБ ОООБООООДОДОДОДОМ50000000 x 


29.5.1 ПІР 


ОООДО0000000000000000001РОООООДООТРООДНТТРОДО 
Арасперорооб0Д000000Міпиаїно5ЕООООДОДОО 


Listen 192.168.125.10:80 
Listen 192.168.129.10:80 


<VirtualHost 192.168,128.10:80- 
DocumentRoot /usr/local/apache2/htdocs/host1 
[other configurations specific to this hast] 
</VirtualHost> 
<VirtualHost 192.168.129.18:80> 
DocumentRoot /usr/local/apache2/htdocs/host2 


fother configurations specific to this host] 
</VirtualHost> 


удобородободрододросиптепіво ОД ]L] « Virtual Host» ПП 
ПОООООООООООООООООООООООООООООоситепёкоо ООО00000 
АраспебдОДІРООООООДОООО00ДОО000000000ДІР 
192.168.128.10[JApache[I[]L] 
[/usr/local/apache2/htdocs/host1[dlt lb] 


LCIDEIDEIEI DIEI Virtua TH os tT JEEETTEIEIEI DE POU 
5ег/уегМате[ППАраспепип t POTE ETE TCTETCTETCULI 
ОДОДОООО000Арасперодродооророродором5Д0000000000Умеб 
О000000000000000000000ғи!у qualified domain namel 
РООМОДОДОДІРООДООМіпеиаїнов5ЕДУДОПОО вЕеп ДОДОДОДОД 
ОМПОО000000000000001РО0000Арасһеп000000 


29.5.2 OULU 


ПОСОООООООООІРОО00000000НТТР/1.10000000Ноѕ00000 
ОДООДОО0000000000000000000000000000001РОООООО0000000 


ПНТТР/1.11111 


ППППППППППППППЫӘШЦППППППППИТИГТГІІ 
http://httpd.apache.org/docs/2.4/ssl/ss| faq.html#vhosts ПОП 


ОООО0000000000ІРОЗО00005510 


0100029.100000Мо21а Firefoxti i ilii nib ib Ii in D URE 
DEIDIBBIOIEY DICIT JEIETD EIE) o S 00000000 


000029.1 0000 


GET / HTTP/1.1 

Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */* 
Accept-Language: en-us 

Accept-Encoding: gzip, deflate 

Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.7 (KHTML, like Gecko) 
Chrome/16.0.912.75 Safari/535.7 

Host: host1.example.com 

Connection: Keep-Alive 


АрасһернНоѕєООВОООО00000000001РО000000000000000 
ООО000000000000000000 


ППАрасһе 2.400000000Матем  иа Ноз ОООООТ РОООООЦО 
ООО000000000000000000000000000Арасће 2.200000000000 
ООО0000000000000000 


ОПОПОАрасве 2.4000000NameVirtualHost00000000000VirtualHost00000000 
ПІР005егмегМатер | 


0100029.2П0Арасһерноѕ 000000000000 
192.168.128.10[ 


000029.2 Dm 


&Only use NameVirtualHost if pre-Apache 2.4 
NameVirtualHost 192.168.128.10 
Listen 192.168.128.10:80 
«VirtualHost 192.168.128.10> 

ServerName host1.example.com 

DocumentRoot /usr/local/apache2/htdocs/host1 
</VirtualHost> 
<VirtualHost 192.168.128.10» 

ServerName host2.example.com 


DocumentRoot /usr/local/apache2/htdocs/host2 
</VirtualHost> 


00000192.168.128.10ПОП00000Арасперодоодрорроррбр0000 
ОООО0000ТРОООООООДОО0О0000000000000000 
по5і3.ехатріе.сопПДАрасперрдоробОО00О0000000000000000 
ћоѕ1.ехатріе.сот0000000ноѕє ООО00000000000000000 
ОО000000000000000 


Пуехатріе.сот0000000000000000ехатріе.сот 00000 
ОООООДО00000000000Р6р.//позкі/ ПОО00000 
http://hostl.example.com/ Ноѕ00000поѕ+110000 
поѕї1.ехатріе.соптОО0000000000000000000000000029.30 
П. О5егмегАаѕ00 


&Only use NameVirtualHost if pre-Apache 2.4 
NameVirtualHost 192.168.128.10 
Listen 192.168.128.10:80 


<VirtualHost 192.168.128.10> 

ServerName host1.example.com 

ServerAlias hosti 

DocumentRoot /usr/local/apache2/htdocs/hostt 
</VirtualHost> 


<VirtualHost 192.168.128.10> 

ServerName host2.example.com 

ServerAlias host2 

DocumentRoot /usr/local/apache2/htdocs/host2 
</VirtualHost> 


100029.3 5егмегАћа5з 


П000000005егмегА'аѕП00000000000000000000ноѕ0 
ОДООД0О0000000000Мігечаїно5іПООДОООПООООДО0О0000000000 


HTTP 1.10)00Но5С00000Н TP III III IIl.1 I III I 
Host[|I IILI IILI IU LIL iHostI II LIL ILI LILILILI ILILILILHPLI III! 
LERest IL ILILIILILILILILILILLILILILILILILILIILILILILIILILILILILILI oo 


ООО00000000000000000000 
29.5.3 00000 


DELIDIOICI Е DocumentRoot] ПП ППТ 


DocumentRoot /usr/local/apache2/htdocs/hostname 


[LI []RostnamerTHLIDLILILIELIServerName DETDIEETE ПП LI I 
ООООО0Д000000000000000000000000000000000000000000000 
ППППППППППППАрасһеПППтоа vhest аһазб дОДОДОДО000000 
ОДОД0О00000Міпмаїдоситепівоої TIE LIApa ch et i Dd ID] 


ОООО00000000000000000000000000000000000015РОДО00000 
ОО00000000000000000 


#Only use NameVirtualHost if pre-Apache 2.4 
NameVirtualHost 192.168.128.10 
Listen 192.168.128.10:80 


VirtualDocumentRoot /usr/local/apache2/htdocs/*1 


П0000%и+иаіІроситепКоо 100% 10000000000000000 
mod vhost ана ПДОООООО0 ОРОР МООООООДООООООО0ДОРОРМ 
00000 


О00000000Мігџа!ІНоѕ#0000000000000000000000 
П/ч<г/оса/арасһе2/һғаосе ППППППППППППППЕООМПППП 
О0000000000Арасһпер00000000000000000000000000 


ОДОД0О00000000000000000000000А паз ДО000000000000 
ОО000000000000000 


Alias /icons /usr/local/apache2/icons 


Options[JUUIFollowSymLInksUIUUUUUUUUUUUUUUUSCFrIptAlias 
ШЕНЕЕЕЕЕЕЕЕШЕ 


ПОООЕМ ча БспрЕАназ0ро /са -етабрроровообо00Осе 
ПП 


#Only use NameVirtualHost if pre-Apache 2.4 
NameVirtualHost 192.168.128.10 

Listen 192.168.128.10:80 

VirtualDocumentRoot /usr/local/apache2/htdocs/*5s1/docs 
VirtualScriptAlias /usr/local/apache2/htdocs/*s1/cgi-bin 


ПЦЦПСО!-ОПЦППЦШИПШППШПИЦПШПППППИПШПСО!ЇШШШПШШИЦШПС9!-б!п[] 


ПОСООООІРОООООООО0О000000000000мМігќиа!- 
DocumentRoctIP[]VirtualScriptAliaslP[] 


29.6 ||| 


ОДОДООДОАрРаєспердррорододрордоророророорододродророод 
\Ммеопоо00000000000000000000000000000000000000000000 
ОО0ОО0000000000000000000000000000000000000 


ОДОДООДАраспердрродрододрордорородророорододродророоро 
ОДООДОО0000000000000ТРООООООДОООООО00000000000000 
АрасһерОО00000000000000000001РО00000000000000001Рр 
ОДООДОО0000000000000001РОООД00000000000000000000 
ОМ5ДОДО0ОО000000000000000000 


29.7 Q&A 


ОбООО00000000000 
АОПОООДОООб0О0О0О000000000000000000000000000УУе000 

ОО0О0000000000000000000000000000000000000000000000 

ООДОО00000000000000300000 


ОПОООООООООО000000000000000000000000000 


АОООООООООО0О0ОО00000000000000000000001РОООО0000 
ОООО0000000000000000000000000000000 


1000 М500000000й те-іо-ІмеПт ТП ПП 
ОО00000000 


2 ОООО0ТРООООООООО000ТРОПО 
ЗОДПОДООДО0000000000000000000000001РОООО0000000 


АПООООІРОООООООООООООООООООО М5ДОДО0000000000000 
ПП 


ОбОООО0О00бРОБОООД00000000000 


АОООООООО0О0ТРОООООООООООО00О00000000000000000000 
ПОРООООООООО РОООООбррОМа me Vi rtu a Host ОДОДООАраспе 2.4 
ОО0000000000000000005егуегМатепдрро0О0ІРОООО00055 ULT] 
ООТРООООООО000ТРОООООООО00000000 


29.8 (ПЦ 


ООООО000000000000000000000000000000000000000 


ӨШ 


ІШПППППППППППППАрасһеПППАрасһеП(ПП 


2 10000000000000000000 О 
ЗППООВИНИОНОВОЕ 


Д4ОПОМи ча Ноз ОО $егиегМатеадтесимей ПППП 


ИЦ 


1000Арасһе0000000000000ріопѕ00ғоПомЅутипКкѕ 
П5утипКкѕ1їОмпегМаёсһ000рег-аігесіогу0000000000000 
ПО000000000тоа status IILI] 


2 ПОООД0000000000000000000000000000000000000000 
ПП 


ЗООПОООД0000000000000000000000000000000000000000 
ООО0000000000000000 


АОДООДДД00000000000000Міпечаїноз 000 
ServerNamedirectiver[lt lr ltml]eerverNamedirective[] 


ОДОД0О000000000000Міпчаїнові0005егуегАПав оДД00000 


0300 ПИШШИП\МЧе LL 


00000000 


• 55І/ТІ-ӘПППППППППППП 
e ПОООДООДОДООД0000000 
• ГППАрасһе 2.2ППДтоа ssl Арасће [||| 


О0000000000000000Арасһероо000000000000000000000 
ОО000000000000000000000%ебоооооо0о000000000000000000 
ОДОО00000000000000го0б000000000000000000УУе6000000 
ПП 


30.1 [| II 


О001пеегпеє100000000000000000000000000000000000 
ООООО00000000000000000001 псегпеєрООО000003000000 


• 000----ОО00000000000000000000000000000000000000 
00000 

• 000----О0О00000000000000000000000000020000000000 
ОООО0000000000000000001000ПП 

° (П-ШІ 


30.2 $54] 


551 П5есиге Sockets LayerIUUUUUUUUUTLSUU Transport 
Layer 5есигі УОПОООООДО0О0О00000000Н T ТРОДОООООДОООООО 
ОДО етте L JIMAPI internet Message Access 
Ргоїосо ПОООПООООПООММТРОМЕе могк News Transfer 
Ргогосо ДООДОО00000055 ЦООООН ТТРООООНТТРЦ 


Месаре019941 11055 Ш1020000 1995 (10055 Ц10307500 
DIE ГРООООО000055 000000 пеегпей ООО000055 03000000 
ОООООДО00000007-5000000Місговой)МеєзсарерДД0Д000000 
ООДОДО00000000000000000000000000000000000000000000 
Lips Su ПООДОДО000000000000551-/715Г0551П 


HEEJURIEJUniform Resource Identifier ОПОООООООО $7 
ПОРЕРОДООДОДОО0О55 00О000000055 ДН ТТРрООООО4 430 


ОО000005501000000000000000000000000000055:0000 
ОО000000000 


30.2.1 IM 


о о ОО 000 0000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ООО00000000000000 


ОО000000000000000000000000000000000000000000000 
П000000005уттеїгіс сгурёодгарһуроо000000000000000000 


ООООООД000000000О5употеїгіс сгургодгарпуПДДОД0ОПРЧбіїс 
key сгурїодгарһуЦП 


100000 


ОДОО0О0О000000000000000000000рЕ;5П0Типріе-ОЕ5ОАСАП 
ВС20О0000000000000000000000000000000000000000000000 
ОООО0Д000000000000000000000000000000000000 


ООООО0000000000000000000000000000000000000000000 
ООООО0Д000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООО0О00000000000000000000000000000 


200000 


ОООО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
00000 


ООО0О0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООООО0О00000000ОРеРООПпУРОСДОООООООООО0 О0О000000000 


ООО0ОО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 


0000000 
| и нн ынан 


ОПООПООПОООООООООООПОПОООООПООПООПООПООПООПООПОБОООПОООООООООДО: 
ОООД000000000000000000000000000000000000 u 


о о ШШШИШИШШЛШЛШШШЛШЛШЛШШШШШШШШШШП 
ПП 


30.2.2 (ПП 


ООО0О0000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ОО000000000000000 


ОООО0000000000000000000000000000000000000000000 
ОП0000000000000000000теѕѕаде аідеѕО0000000000000 
ООО0О00000000000000000000 


ООО0О0000000000000000000000000000000000000000000 
ОООО00МОЗ5О05НАП 


ПООДООДООДО000000000000000000000000000000 
[message authentication code |JMAC ПП ПППППППППППППП 
ПООДООДООДО000000000000000000000000000000000000000 
ППНМАСПНавһ Message Authentication СоаеЦПНа$һПЦЦЦППЦИПП 


ОО0000000000 


о о ПОДОМАЄДООО ОООООО0000000000000 


30.2.3 [JII 


о о ОО 000 О0000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ПП 


ООООО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОО00000000 


ООООО000000000000000000000000000000000000000000 
ООО000000000000000000000000000000000000сегипсайоп 
аиќһогіёурсАПО0000000000000000000000000000000СА000 
ОООД000000001п:егпеєрОПОООО0000000000000000000000 
САП 


САПОООООДООООООООО0О0О00О00000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
000000 


ОООО0000000000000000000000000000000000000000000 
00000000 


ОО0О000000000000000000000000 
1155 Ц [| 


ООДО0000000Х.50900001п:егпеєрД000Х.509ПП00000000 


° 000-- 00000000 

° (П-ШІ 
О0000----000000 
О0000----О0О000000000000 
° 00----О0000000000 


ОООО0000000000000000000000000000000000000000000 
ОООО000000000000000000000000000000000000000000000 
о о ДОООО0000000000000000055-000 
http://www.amazon.com/UUUUUUUUUUUUUUUUUUUGIobalSiganLILl 
О030-10О000000000000000б11обаї|5і1ап ППТ ПТ ПП 


= еы 
/ а Amazon.com - Your Accou х \ 52) 





Certificate 





















€ Q А https//www.amazon.com/ap/css/home 3 

|| [General | Details | Certification Path = 

amazon.com Hello. Sign in to get personalized 
س‎ Your Amazon.com |  # Today 


[Shop All Departments v Search ДІ Departments 





Field Value i5 
[=] Signature algorithm sha 1RSA 
| Signature hash algorithm shal A 
Your Account SSLIET VeriSign Class 3 Secure Server... | 
1 | Wednesday, July 14, 2010 7:... 
Orders View, Modify, Track. | Valid to Sunday, July 14, 2013 6:59:5... 
See & Modify Recent Orde Cancel an Order | E| Subject WiWW.amazon.com, Amazon.c... 








— а аа ubli RSA (1024 Bits) 

vir Mentre ie а Вале atraint Gubiact Tunis Ет Entity Dat 
Order History [CN = www.amazon.com 
View Open Orders e E 
View Your Digital Оге 
Download Order Ref 
View Your PayPhrasi 
View Your Kindle Ore 





More Order Actior 
Return Items or Gifts Learn more about certificate details 
Manage Subscribe & 
Manage Magazine 5 
Leave Seller Feedba 
Leave Packaging Fade 
Manage Prime Membership 
View Your E-mails with Sellers 


4 | "m | һ 


П30-1 ммм.ата2оп.сот 1115521 ПП 


0030-100000005ичб)ес ПДОАтагоп.сопабіЯсбб000000000 
000000000000000Оммумми. атпа2оп.сотП[ 


(00005 ТООООПЕООООДОрО0О00СЄМОДОДОДО000УУеОДОДОПО 
ОДб0000000У/евбородрооб00009 R СООДООД000000000000 


www.amazon.comr([] [LET www ПОПООООО0000000000000000 
ШШЕ 


ПОСМО“. ата2гоп.сот ПД ДдОДатагоп сога ОПОООООУ 54100 
ШИШЕ 


2155-1000 


ООДО000055 0000000000000000000000000000000000000 
ОО000000055 00000000 


1 ООД000000000000УУео000 

2 П000000000000000000000000 
ЗОПОООД00000000000000000000000000САС00000 
АД ОО0000000000000000000000 
ЗОООО000000000000000000000000 


б ООО0000000000000000000 


30.3 (00055 Ц | 


055:100000000тоа 55ІДАрасперд00000000000Орепь51 
ПО00550/7ТЕ500000000000000000000000000реп55 Егіс 
A.Young[]Tim J. НиазопП)0055 (еауп 


ООДО00000000000000000000000055.0000000000000000 
ОООО0000000000000055:0000000000 


30.3.1 OpenSSL 


ППОреп5 5 Ц ДЦОДИДОДОДОДООВНЕр'// ммимм.ореп55і.огд/ 00 
UNIX/Linu хОДОДОО0О000000000Ореп55:.ПООООДО0О00000000000 


[IiWindowsli|[ IILI IILI L IILI LIL ILI LIL ILI LIL LILIIWindowsli|[I[| 
П0000Орепѕ55:100000реп55:П000000000000000000000 
mod ssl АрасһерО0000000000 


1| Windows || ILLI] 


ОООООДО0000000У/ пасом TEIEIIEILIO pen S SELTEYETETETLI 
Орепѕ5:1110000000%1паомѕ0Орепѕ5 0000000000 
ІМ 5 ТАЦІ. .МУЗ20ОДОД0О00000000000000000000000000000000 
UUUUUUUUUUActIveState Perl Тог Міпаом5 ОДОДОДОДОСОДО 


e Visual C++ 
• Вопапа С 
• GNU С (Судміп ог MinGW) 


ПОДОДО0000000000000000000000000 
http://httpd.apacheorg/docs/2.2/platform/win compiling.htm 


| [II]I]Apache[]]OpenSSL[TLL 


оПОМІХЛіпихООГО 


0000000 пихПЕгеевѕрп0000000реп55: 100000000000 
П000000000реп55 1000ореп55:0000000000000000000 
саро000000000000-мегѕіоп000000000репѕ5 0000000000 


# gunzip < openssl-version.tar.gz | tar xvf - 
# cd openssl-version 


ОДОДОД00001М5ТАСОООДОДОДОДООСопЛАЗ9ДООДОДОООДОДО 
ОО плакерптаке install 


30.3.2 Арасһе[тоа ssI[][] 


ПООАрасһер55:ПО000000000000000000тоа 5510000 
Apache 2.20О000000000000000009МІХ/ іпих ep il] 
ү/іпаоуФЦПППППИППИПППАрасһеП тоя ssl[][]]]pmod $51000 
ОО00000000000000поа з5і))00ПОреп55ЕПп0)р0000000Орелп551 
ОООО 


1 [| (Windows 


ОДООО0000000000000000000000070репз5і"ДО000000 
httpd-2.2.22-wiIn32-x86-openssl-0.9.8t.ms[][]HE]Windows][] 


Apache 2.2.22111111 


ПППИППППППАрасһе 2.40 d Windows ПППОПИПИИНИНОВОВОВ 
ОО000000000 


ПО00000тоа_ѕ51080000реп55Арасһер 6600 
http://httpd.apache.org/ 
docs/2.4/platform/win compiling.html [ApachelUUUUUUUUUL 


ООООО000000000000000000000000000000 


• ПОрепз5 110 
e Microsoft Visual C++ 5.000000 
e Windows[TISDK[] 


е амКПППамикПдам/КППППППП 


2 ПОЧУМІХЛ іпих ОО 


ОЗОДО00000000000000тоа 55І0000000000000тоа _551 
ОМІХЛ ПУ ХОДОДО0000000000паке/паке ітѕёа 0000000000 
ОО00000000 


--enable-ssl --with-ssl-/usr/local/ssl/ 


ПООООВОВОВЫООВЕНО рей 54 ИПИНИНОНВИНОВОИНОВОВООВ 
ОООДО000000000000000тоа 55ІП00АрасперрододороооФО 
ООО00000000000000000000 


# /usr/local/apache2/bin/httpd -1 


Птояа 55ІПООДОДОООООДД00000000000Арасперродр00 
(httpd.conf)[] 


LoadModule ssl module modules/libmodssl.so 


ООДОР'ЕЄра. соптДОДООО0О0Д00О00Арасперрдоооррооро0б000000 
ППегтог logrjmod 55 ДОДООООО000000000 


Apache/2.4.1 (Unix) mod 551/2.4.1 OpenSSL/0.9.8t PHP/5.4.0 


30.4 {ULL 


П0000000реп55 тоа ѕ51000000000550)000000000000 
О0000000000000000000орепѕѕіІП00000000000000000000000 


ОДО000055:0ОО00000000000000000000000000000000000000 
ПП 


ПППППШШПШШПШШореп55!ПОМ1ХЦПШШИПШШП\МЇпао\/ППШШШИШПореп551.ехеЦПППШП | 
000000000000000000000О0О00ОО0О0о pen SS 0000000000000000000000000000О 


ООООО000000000000000/ 00000000000000000000Р00МОД 
мм. ехагпріе.согП ДОДООООООД0О00000000 


# openssl genrsa --des3 -out www.example.com.key 1024 


° депгваддПОреп55 00000000000 
° аеѕзППО000000000000000000 

° ОЙТОООО00000000 

• 102400000000000 


ООО000000000000 


Generating ВЗА private key, 1824 bit long modulus 
о зе в CRACK UE RC T4 
РТРС ++++++ 


е is 65537 (0x10001) 
Enter pass phrase for www.example.com.key: 


ОО0О0000000000000000000000000000000000000000000 
ООО0О0000000000000000000 


и 
ООО000000000000000000000000-4еєззоПОДООООООД000000000 


# openssl rsa -in www.example.com.key -out pes example.com. kay unsecure 


LL] www.example.com.key[tJ ДДОДОДООО0Д00О0000000000000 
00000 


# openssl rsa -noout -text -in www.example.com.key 


ООО000000000000 


30.4.2 [III 
ОДОСАОДООООДООООООООО0000000000000000000000 


# req -new -Кеу www.example.com.key -out www.example.com.csr 


ООО0О00000000000000000 


Using configuration from /usr/local/ssl/install/openssl/openssl.cnf 
Enter PEM pass phrase: 

You are about to be asked to enter information that will be incorporated 
into your certificate request. 

What you are about to enter is what is called a Distinguished Name or a DN. 
There are quite a few fields but you can leave some blank 

For some fields there will ре a default value, 

If you enter '.', the field will be left blank. 

Country Name (2 letter code) [AU]:US 

State or Province Name (full name) [Some-State]:CA 

Locality Name (eg, city) []: San Francisco 

Organization Name (eg, company) [Internet Widgits Pty Ltd]:. 
Organizational Unit Name (eg, section) []:. 

Common Name (eg, YOUR name) []:www.example.com 

Email Address []:administrator@example.com 

Please enter the following ‘extra' attributes 

to be sent with your certificate request 

A challenge password []: 

An optional company name []: 


Common Матеооообобом/евпооооовооововооообоц 
ООООО0000000000000000000000000000000000000000000000 
000000 


0000000Оммумму. ехатпріе.сот.с5ГДОДОДООООО0О0000000 
ПП 


# openssl req -noout -text -in www.example.com.csr 


ООООООДСАО000000000000Мегі5ідпОТпамтедМебмогк 
зоїикіоп5ООДОСАОООООДОСАДООДОДООООООООДООМегізідоП 
Thawte[]Network Ѕоіийопѕ= 0000000000000 


е VeriSign—http://www.verisign.com/ssl/ 

е Thawte—http://www.thawte.com/ssl/web-server-ssl- 
certificates/ 

• Network Solutions — 
http://www.networksolutions.com/SSL-certificates/ 


30.4.3 [JII 


ОООО0000000000000000000000000000000000000000000 
ОДОД0О00000000000000СА00000000000000птоа 55І0000000 
ПППу/ео 000 


й openssl х509 -req -days 30 -in 
www.example.com.csr -signkey 
www.example.com.key -out www.example.com.cert 


000000 млм. ехатр!е.сот.сег ППППСАППППИПППИПОПИП 
ЦЦЦ/и5гЛЛоса!/551/ореп<51/сегї5/ППЦПЦППППП 
[/usr/local/ssl/openssl/private/[] 


ОО000000000000000 


# chmod 409 www.example.com,.key 


ОО000000000го:00000 
30.5 SSL] 


ООДО000055Е000000000000000000000000000000000000 
ПППППАрасһеП п 0000000000000тоа 55І00ОО0000000000 
ПППППППППППППППППһ ра. сот ПП Об оаамМоамте T T] 


Apache 2.2.Х00007 000" ОДООООДО00000000558000000000 
ОДООО0000000МЕра. conf ДОДОДОДО 


Include conf/extra/httpd-ssl.conf 


III Lh ttp d -ssT.confE ООООООДОДОООДОДОДОДО000000 


UseCanonicalName Оп 

<VirtualHost www, example . com: 4432 

ServerName www.example.com 

SSLEngine on 

SSLCertificateFile /usr/local/ssl/openssl/certs/www.example.com.cert 
SSLCertificateKeyFile /usr/loca/ssl/openssl/certs/www.example.com.key 
</VirtualHost> 


ПОООО0О000000000000004430000НТ ТРБОДОООДОДОО 
SSLEnginerpIDDp I IsLrsSLCcertificateFile|] 


551 Сегипсагекеутепрбобовоооооовововововобоц 


ПП! 


ПППППИПППГПГППАрасһеП ПППППАрасһеП IL IILI 
apachectl <5Сагї5$51ППЦППППШЦППИПШЦШПШИШШЦШШШШЦШШШШЦШШЦПАраспһе[ 
ПЕ НАраспеп И ПараспесН start ППППППИПППГИП 
ПЕра-$$1.соп 0000 ра.соп ППППППППППАрасһеПППП 
550000 


ОО0О0000000000000000000000000000000000000000000 
LOBO UD Apache pb D IEEE EIhteps ://ww w.example.com/ 
ПУБ СДОДООДб0О0000000000000000000000000000000АрРаспедрб 
ОО0000000000000000000000000000000Арасһероо00000000 
О000000000000443000 


30.6 ПП 


0000055 О0тоа <<1ППШППтояа 55ІДП0055  ПОПАраспебп 
ПО00000Орепѕ55 тоа 5511000000000000орепѕѕ51000000000 
О0О0000000000000000 
http://httpd.apache.org/docs/2.4/mod/mod ssl.html [] 
тоа _55100000000000000000000000000055010000000000000 
ПООО00000000000005П000000000000000 


30.7 ОФА 


ОбООО00000000000055И1П 


АОДОДОООДД0Д0000000000000055.00000000000000290000 
ОООООДО000000000Н T ТРОДОНОо5ЕОДООООООДОДОДО5ЕДОООО 
ОДОДО00Н T ТРОДООООООООДОО0О0О00ОНТ ТРОДОТЬ5ОДОДОДОДОДОП 
NOOOgooocoohttp://www.rfc-editor.org/rfc/rfc2817.txt ПВЕС 
281700 


ОбООО00000000055И1П 


A[]mod ѕ5100055:1000000000000000Арасһеро00000000 
00000551000 


30.8 [I 


ОООО0000000000000000000 


ӨШ 


100001пегпеє 0000000030000 


2 П00000000550]Арасһер0 


ЕШ 


1000000000000 


2ЦЦЦһїра-$5!.сопЇШЦПЦПЦППЦППИЦПППЦПһПїра.со п ЦЦЦПЦППП 
apachectl start] 


1310] ООО0ООМУу50І 


00000000 


IJMySQLII[ IILI ILIL III II III 
MySQLII[IL II II II II 
ПППОРТІМІГЕ TABLE] [| 
ПОООЕХРСАМ (| 
ООООРЕО5НОДОДООООООООООО 
ОО005 НОМУПОООООООООСбО0000000 
ОО005НОмМУПООООООО0О 


ООДОДО000Му 5ОЄПООООО0О00000000000000000000000000 
000000 


ООООДОДО00МУЗОСГДООДОООД0000МУзої  М/огкбепспО00000 
http://www.mysql.com/products/workbench/ ПООООбООД00000000000000 


31.1 БОООООООО 


ОООО0000000000000000000000000000000000000000000 
ОООО0000000000000000000004000000СРООДОООДОД0000000 
ОООО000000000000000000000000000000000 


CPU ——CPUIIIIIMySQLIII L IULILILILILILILILILILILILL13.OGHzII LIU 
П1.0СН ППППИППППИПППППИПППППППИПППППППИППГТПГТГІГІ 
000000 

ПИП —=О0ОООООКАМЦОООООООООООКАМООООООООООООООО 
ООДОСРОДОООО 

00000 ----ОООО0000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000 
ОООО0000000000000000000000008090000000000000000 
ООООЗОЗООО0О0О0000000000000000000000000000000000 
ОО0О000000000000000 

0000 - ---ООООДОО00С0О000000000000Уміпаом в ООО0О000000 
ОООО00000000000000000000000000 


ООООО0000000000000000000000000000000000000000000 
ООО0О000000000000000000000000000 


MySQLTITITBBIBIEMyIS AMI Inno ОВОДОООДО 0000000000000 
ОООДОДООО00О00000Му5ОС0О0000000000000000 
http://dev.mysql.com/doc/refman/5.5/en/optimization.html [] 
LEE] LIhttp://www.mysqalperformanceblog. com/ []MySQL 
Performance[][][] 


ППрепсћтагк()[ 


П00000Му50 репећтагк ООООООО000000000000000000 
ОООО000000000000000000000000010ч10000000000000000 
ОО00000000 


О000000000000бепепптатк 0000000 бепспптатк ОДОД0000 
ООООО0000000000000000000000000000000000010ч4-100П00 
100000 


select benchmark (1000000, 10+10}; 
ООО000000000000000 


| БепсһтагКк( 1000000,19%10) | 
ворони віза врана дб снес + 


1 row in set (0.04sec) 


ОООО000000000000000100000 


select benchmark (1000000, extract(year from пом ()))г; 


ОДО000000000000000 
Pi Ce ни 
| 9 | 


1 row in set (0.095ес) 


ОООО000000000000000000000000000000000.040000000 
О000.0900000000000000000000000бепсебплагк О0О000000000 
ОО000000000000000000000000000000006репсћтагко000000 
ООО000000000000000000 


31.2 MySQL 


MySQL АВОДОДОООООО0ОО0О00О000000000000000000000000 
ООООО00000000000Му5ОС0ОООООДОООО0О0000000000000000 
ООООО0000000000000000000000МУ5ОРОООО000000000 


ОДО00РЕЄр ://dev.mysql.com/doc/refman/5.5/en/server-system-variables. | 
html Омузошоооооооооооооомузо оообообету.споооооооооооооооооооо · 
ООО00000000000000000000000000 x 


[MySQL Isuppor-files[I( IILI IL ILIWindowsi|[ II I II III I! 
ООООО00000000000000000000000000 


е my-small.cnf - - -ДОВАМПО64АМВИДООДООМу5ОЄООООП 


ПП 
е my-medium.cnf ——ППЕАМЦ(6 4 МВИПОПОПОМУЗОЦ ПОП 


ПППППИППППИППППКАМ 12SMBIIIMySQLIIL LI LI III II III 
ОДОДОДСОМу SQ СДОДОДОПУУерОДООООДОООДОДОДОДО0000 


ШІ 
е my-large.cnf ——||КАМ0128МВ 5 12 B[IEIE]LILILILI 


MySQL 
° ту-һиде.спҒ--ППВҺАМП1ОВП2ОВПППППППМУ5ОЦТПГП 


ULL] 


ОО00000000000000000000000000000000/еёс/ту. сп 
my.cnf[ ПП ПП 


00000 


ППШПШШЦШШИШШЦШШИШШЦШШИШШЦШИШЦПКеу_ОшТег_5!ге[ 
table саспедрдПДО ОДОДО0О0000000000000000 


key buffer 5ігебОДООДОПО0О00000000059О0200000000000 
ПППППППППППИППППИППИППППИГППИПКАМ(|512МВГПППППІ 
256МВОкеу buffer 5І22000000256МмВДОДООО0000000000 


[010000000000000000000044000000Кеу_геаа_геадче5Е5П 
key reads[]key write requests[]key writes[][L]LIEILILILIL]S HOW 


5 ТАТОБОДООДО00000000 


ОООО0000000000000000000000000000000000000000000 
0000 


| Key read requests 
| Key reads 

| Key write requests 
| Key writes 


160182771 | 
9326 | 
48487 | 
2287 | 


ППППКеу геад$ПОП0ПКеу read геаиез 5 110000000о. 02100 
П0000Кеу мгіёеѕП000кеу write гедаиеѕ$П0О00000010000000 
00000000000000.000915861721998[0.047167281951863[ 
ПОСООООСООООООООО0О0000000кеу биїег 5ігебПООО000000000 
ОО0000000000 


оробр000000бабіе cach er in pb p Dp ie 411] 
ООДОД0ОО0000000000005НОУУ 5ТАГО5ПДООО00000000 
ореп_фа Ме ДДОДОД0000000Обабіе сасрердр 0000 


ОООМУЅОЩООО0000000000Кеу buffer size[ [table cachellll 
ОДОДбОДО00000000000000Д00000000000000000000000000000 
ОООДбОб00000000000000000000000000000000000000000000 
0000000 


31.3 [ILI 


ОООО0000000000000000000000000000000000000000000 
ПППИППППИППППОӘРТІМІГЕ ТАВСЕДПОООООО0О0ОО0000000 


OPTIMIZE TABLE table name[,table name] 


О0000000000се5:08000009госегу inventory ПОПО 
OPTIMIZE TABLE grocery _їпуепїогуЦПЦЦПЦППППППППППППП 
ПУОКР"ИООООООООЦО Table does not support optimize,doing 
recreate + analyze instead” "ОПО 0000000000000000000000 
ИОН 


31.4 (ПП 


ОООО00000000000000Е2ХРЕАТМООООООООДБЕСНЕСЄ ТООО0О0О 
ОДООООО0000000000000000000000Ш0Ш01МООООДОООП0ЕХРІАІМО 
00000 


EXPLAIN SELECT statement 


ЕХРЕАТМДООООО000000000000 


id — 00000100 

select type --- -5ЕГЕСТОДОПОДОООПОО 

table —— ||| 

type ----ПООО00000000 

possible keys -ПППППМУБОНПИПИППИППИПППИПИПГІГІ 
ПОМО ЦД ПООООООООООООООООООООООООвООООООООООООООо 
WU 

key —— - ОПООООДО000000000000МО1 10 

key len -- - -ОДООООДОО0000000 

ref —— ДОД О0000000000 

rows ——l l IMySQLIII dbi 

extra ——ПОМУЅОЦОООООООО000000000000095іпо index 
ОООООДО0ОДУупегеродбодОУУНЕКЕЛОДО 


ПОЛОВОЕ ООО0О000000000000000000000УУНЕКЕООД 
possible кКеу5 ППППППРАЕМАВУППЕХ га ППОПООО\Мбегей 


ПООШДОТМООООНОЕХРЕАНМОПОВОВОВОСОВООООНОВООВОЕ 
ГгоМ/ӘПППППППИППӘТ ПИПППППППИППППОПППИППППМУБОНТТППП 
ООбО00000000000000000000000020000000 


ОООООЕХРЕАТМОДОДОДОДОООГО 
http://dev.mysql.com/doc/refman/5.0/en/ explain.html П 


MySQL[TT] 


31.5 ЦЦПЕКОЗН || 


ООДОО00000000000000000000Р-05НОДО00МУу5ОЗ000000 
О00000000гоо С ДОООДОДОРЕО5НОДОООДО00000000 


РЕО5НОДОООО 


FLUSH Flush option 


РЕО5НОДОО9 ОООДО00000000000 


• PRIVILEGES 
• [ABLES 

• HOSTS 

• [065 


ПОООООВОВОРЕУ$Н РАТМІЕСЕЗООО ООООО0О000000000000 
ОМу5О СООООООО0000000000000000000000000МУ5ОС000000 
[[]JFLUSH PRIVILEGESQQQ0UQuery ОКО00000000000000 


mysql> FLUSH PRIVILEGES; 
Query OK, @ rows affected (2.10 sec) 


FLUSH ТАВЕЕ5П00000000000000000000000000000000 
МУ5ОЦШООО00000000000000МУ5ЅОООО0000000000000000 
Query ОКППП 


mysql> FLUSH TABLES; 
Query OK, 0 rows affected (9.21 sec) 


FLUSH HOS ТЬООООООООООО000000000000Му 5ОЄ0О000000 
ООООО000000000000000000000000000000МУ5ОС0000000000 
ОООО00000000000000000000000Е005Н HOS ТБООООО00000000 
00000000 


mysql> FLUSH HOSTS; 
Query OK, 0 rows affected (2.00 sec) 


FLUSH СОО5ПДО0О0000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ОО0О00000000000000000 


mysql> FLUSH LOGS; 
Query OK, @ rows affected (0.04 sec) 


ОДОДОРЕО5НОДООООООООО 
http://dev.mysql.com/doc/refman/5.5/en/flush. html []MySQL 


ULL] 
31.6 (05НОМ|| 


SHOWTLIDEIDOULDDOUBDUBOUUDUM y S QU OOOO 
ОООО00000000005НОМУПООООООО0О0000000000000го0080000000 
ОО005НОМУПОПОДОООО0О00000005НОМУПОПОДОООО0000000000 


SHOW GRANTS FOR user 

SHOW DATABASES [LIKE something] 

SHOW [OPEN] TABLES [FROM database name] [LIKE something] 

SHOW CREATE TABLE table name 

SHOW [FULL] COLUMNS FROM table name [FROM database name] [LIKE something] 
SHOW INDEX FROM table name [FROM database name] 

SHOW TABLE STATUS [FROM аб name] [LIKE something] 

SHOW STATUS [LIKE something] 

SHOW VARIABLES [LIKE something] 


SHOW GRAN ТБПООООООООО0О0000000000000000000000 
ООООО000000000000000000000000005НОМУ БКАМТ5ОООООЦО 
ОО000000000000000000000000000оеиѕего0000 


SHOW GRANTS FOR joeuserelocalhost; 


ОО00000000 


| GRANT ALL PRIVILEGES ON *.* ТО 'joeuser'@'localhost' IDENTIFIED | 
| BY PASSWORD ' *13883BDDBE566ECEFF@5@1CDE9B293303116521A' 


1 rows in set (0.00 sec) 


ПО0О00Обкоо 000 E eeuser ПП p i Ei Engine et ШИШИП 
ОО0000000000000000)0еч5егурро00000гоо ОДОДОДОП 


SHOW GRANTS FOR root@localhost; 


ООО0000000000000 


ERROR 1944; Access denied for user: 'joeuser@localhost' to database ‘mysql’ 


ООО0000000000000000000000пг008 000000000000000000 
ООО000000000000 


ООООО00005НОМУПДОДОООООДОДОДОО 
http://dev.mysql.com/doc /refman/ 5.5/ еп/ show. html [| 


муз ОД 
31.6.1 [|H III 


ООООО00000000000005НОУУ ДОДОМУ 5ОЄ0ОООО00000000 
ПППИПППЭНОУ/ РАТАВАЗЕППОООООООООООПОДОМУ5ОС0000000 


0000000000008 
| Database | 
| tests | 
| mysql | 


2 rows in set (0.00 sec) 


ООООО0000000000000005НОмУПОООООДО0000000000 
Ге ОВОДОДОДО0005НОМУ ТАВСЕЗПДПОООООООООО00000000 


З НЕНЬ РИ Р ымы on bentes + 
| Tables in testDB | 
%--------------------- + 
| grocery inventory | 
| email | 
| master name | 
| myTest | 
| testTable | 
dicis ты анна налыды + 


5 rows in set (0.01 sec) 


ПООЗНОМ ТАВСЕЗПОДОПОРЕМ ДООООООООО00О00000000000 
ОО0000000000 


SHOW OPEN TABLES; 


0000000 


Рика ска pe tee SESE nM |l  "——— жй t 
| Database | Table | In use | Name locked | 
ылы Бетине; E E Po s و‎ ese экы вы йе + 
| mysql | ргос5 ргім | @ | 0 | 
| mysql | db | 0 | 9 | 
| mysql | host | ð | 6 | 
| testdb | grocery inventory | ð | @ | 
| mysql | user | @ | 0 | 
| mysql | tables priv | ð | 0 | 
| mysql | columns priv | @ | 0 | 
Jee hese s я Eases mim Es вон sum К Балы e xn ТҮ: rns + 


7 rows in set (@.@@ sec) 


ОООО00000000000Р205Н ТАВЕЕ5П0000000000000000000 


ООДО0000005НОМУ OPEN ТАВСЕЗПООООООО0ОО0О0000000000 
FLUSH ТАВЕЕЗПИИПОЦОЦ 


31.6.2 MN 


OOUOUOUUSHOW CREATE ТАВСЕПООООООООООО0000000000 
ОО0000502000 


SHOW CREATE TABLE grocery inventory; 


HEH 
|Table | Create Table ы ы ооо | 
|н ee ee ee eee eee + 


| grocery inventory | CREATE TABLE 'grocery inventory' ( 
id' іп%(11) NOT NULL auto increment, 
item name' уагсһаг(50) NOT NULL default " 
item desc' text, 
item ргісе float NOT NULL default 9”, 
“сигг qty' intí(11) NOT NULL default 'Q', 
PRIMARY KEY (714!) 
j ENGINE-InnoDB DEFAULT CHARSET=latint1 
Жо» ще —— M ll — —: + 
1 row in set (@.0@ sec) 


ООООО0000000000000000000000000000000000000000000 
ООДОДО005НОУУ CREATE TABLELI IILI II III 


ОООО0000000000050С:П0О0О00000000005НОУУ COLUMNS 
ПП 


SHOW COLUMNS FROM grocery inventory; 


[IILI JLI IILI 
bes sa suu z Topa asme ansa | dengue ОЕР НЕЗЕЕ ызы es изаа — + 
| Field | Type | Null | Key | Default | Extra | 
accom Sole ноя j—— РЕ ——À — —— M diens ls + 
| 10 | int(11} | NO | PRI | | auto increment | 
| item name | varchar(50) | NO | | | | 
| item desc | text | YES | | | | 
| item price | float | NO | | | | 
| curr_qty | int(11) | NO | | | | 
1 ——S j| ———— doses +----- еи нЕ CG a ре + 


5 rows in set (0.01 sec) 


SHOW ІМОЕХОДОООООООООО000000000000000 


SHOW INDEX FROM grocery inventory; 


ОООО000000000000000000000031-420000000000000 


031-1 SHOW ІМОЕХОЛООО 


Non unique 10001 =0000000о - 0000000 


EXE 
- 
= 
-— 


ООООО00000000000000005НОМУ TABLE 5ТАТО5ПОО000000 
0000000 


SHOW TABLE STATUS [FROM database name] LIKE 'something' 


ОО00000000000000000000000000ачёо іпсгетеп 00000 
О00000031-200000000000000 


031-2 SHOW TABLE БЗТАТО5У [ПЦ 


ej or 


000000 
0000000 
00000000 








31.6.3 [ШШШ 


SHOW STATUS[JSHOW МАКТАВ(Е5ПООПООООООООООООООО 
UUUUUUUUUUUSHOW STATUSUSHOW VARIABLES[] 


ППШПЗООЦПЦППЦПП5ЭНО\\ 5ТАТО5ПОО0О00О00000000 


Aborted connects ——ПОО00МУЅОЦШОООООООООО00000 
LIETLILILIDIDIDI DIEI AE IE TETTE TETETETETE TC ICI TL TL TL TL TL TL IL DIDI IE ETC TETTE TLTL] 
ОООДО0000000000000 

Connections —— ПДДПООООО0О00000МузосоДоордбодод 
Max used connections ----ПИДПОООООДО00000000000 
ПП 

Slow queries ——{[][Jlong query _timelUUUUUUUU 
long_query_time U1 ODDIDBDD D D B D B IU IL IL ISQLI 00 
Uptime ----ДДООО00000000000000000 


HL LIhttp://dev.mysgl.com/doc/refman/5.5/en/show- 


status.html ОМу5ОСДОДОДОДО5НОМУУ 5ТАТОБПППИПИПИПИППИП 
ПППП 


SHOW МАКІАВГЕ5 003 25 ПДПОДОООООДОМУу5ОЄ00000000 


0000000 


connect timeout - - -"ДЛМУу5ОСПОООДООО0000000000000 
max connections —— -ОПОПОООООД0000000Му5О-000000 
ПОД 

port ——Музо ПОООЦ 

table type ——Музо ПООО 

version —-МуБОЦ 10000 


ПППһҺЕр://дем.тувд!і.сот/аос/геттап/5.5/еп/5һоуу- 
variables.html ПМУБОЦГЦПППППЫНОУУ УАКІАВІЕ5ФПППППППППП 
ОООДОД00000000000000000000000МУЗО:ДОДОО0О00000000 


31.7 ПП 


ОДОД000Му5ОРО0ОО0О0000000000000000000СРООО00000 
ООДОДООВАМОБООСРОДОДОООМУуЗОРПООООООДПУУЄеБОДОДОДОДО 
0000000 


ОООО0000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ОООМуЗОСООООО00О00000000000 


МУБОГТТПППІПППІППКеу buffer size[]table cache]QUU00UL 
ПОООДООО0Му5ОСбОДОДОДООД0О0Д0000000000000000000000000 
О000000000000 


ООДОО000000000000005ЕСЕСТООООООДОО0ОДОРТІМІ ЕП 
ООООД00000000000000000000Е6ХРЕАТМОДООООСОДООО0О0000 
ОООО00000000000000000000000000000000000000000 


ОМу5О СОООООДОООО0О0000000000РО95НОУНОМУПООО00000 
ООООО000000000000000000000000000МУ5О081000000000000 
ОООО00000000005НОУУДОДООДОО ООООДО0000000000000000 
ПП 


31.8 О&А 


ОПШШШШИШМУ5ЗО ЕДОППОСРУЦОООЦ 


АОООДООО ОООО0ДО0СРОУД0МУЗОСРОДОООООООООО0000000000 
LLICPU[IMySQLII[ I JLI III] 


QIIIIOPTIMIZEI[I[ E CE II) 


A[JLILILILILIIINSERTII I LILILILILILILILILIOPTIMIZELI LI III III 
ЗЕГЕСТИООООООДОРТІМІЛЕНОГ 


31.9 ППП 


ОООО000000000000000000000000000000000000000 


ӨШ 


ІПППМУ БОППППИППИПИППИППИПИППИППГТГП 
2 О5ОС:ПОД000000 
3LIILIFLUSHII[ILIIMySQLIIUI III 


АПОО000МУЅОЩООЦппоовро00005НОМ STATUSII[J 
SHOW VARIABLES[] 


SLLILILIISQLIIII II III LIL ILIIimyTablie[I[ISQOLII[ II 


ИЦ 


1Пбепсћтагк О DO 
2ПОРТІМІ2Е 
ЗПЕШЅН LOGS 
4[]SHOW VARIABLES 


о ПБНОМ CREATE TABLE myTable 


ЦИН 


1000000000оо#00000000Кеу buffer size[]table cache[] 
П000000000000репсһћтагк()0000000000000 


2 ПО00000000000000РТІМІ2Е000000000000 


ЗПООБНОМ 5ТАТОБПДОДОДОМУ 5ОСОООООООООООРЕО5НОП 
ООООО0О0000000000005НОМУ 5ТАТО5ПОООО0000005 HOW 
ЗТАТОЗООООО0000000 


П321 ШШШ 


00000000 


ОО0000000000 

° ППШПМУЭБОКПТППППППИП 
° ПОДАраєперрророо000 
° ПООРНРеОДООДОООО 


О0000000000000000000РНРЦАраспе0мМуѕо 00000000 
ООООО00000000000000000РНРОООООООООООО00000000000000 
ООООО000000000000000000000000000000000000000000000 


32.1 ШШШ 


ООООД000ОАраспеоРНРОМу5О0:0000000000000060006000 
ОДОД0О000000000000000000000000000Умебодродоор0000000 
ОООО000000000000000000 


° ПІПМУБОЦПППҺЕр://15%5.туса!.сот/ ППОМУЗОЦШООЦО 

e ПШАрасһеППІ 
http://www.apache.org/foundation/mailinglists.htm!l 000 
Арасһе 10100000 

e ПООРНРОООО Ср: мм. рћр.леЏта па. Пєє5.рпр ПППРНР 
00000 


ӨШ! 


ООО0О0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
OOL 


90000000 паогліпоггемізіо Пп ДОДОДОРНР 5.4. 000000500 
ПОП4ДДОДбОДОбОДОДО00000000000000007 007 0000000000000 
ШЕШЕ 


ООООО0000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000000000000000 
ООООО000000000000000000000000000000000000000000000 
ОО0О000000000000000000000000000000000 


ПППАрасһе ПДООООО0О0000000Ш102.0.6102.0.630000000000 
2.0.620000000000000000000000 


SECURITY: СМЕ - 2007 - 6388 (суе. піїге. ого } 
mod status: Ensure refresh parameter is numeric to prevent a possible XSS 
attack caused by redirecting to other URLs. 


ПОО000000007000О5есигісу H” О0000000000000000000000 
РНР5 OUUUUUUUhttp://www.php.net/ChangeLog-5.php 000000 
ПОДОДОДОДОО00О000000000000000000 


ООО0О0000000000000000000000000000000000000000000 
ОООО00000000000000АраспебРАРОДОООООЗОДОДОДОП 


mpm winnt: Eliminate wait for many objects. Allows the clean shutdown of the 
server when the MaxClients is higher then 257, in a more responsive manner. 
Fixed bug #43137 (rmdir() and гепате() do not clear statcache). 


ООО0О0000000000000000000000000000000000000000000 
ОДОО0О0000000000ОРНРОДОДООДОДОДОДОБУ900 УМ пасом 50000 
ПОВОООН пох ОДОРНРОДОДОООДОДОДОД0О000 


ООО0ОО0000000000000000000000000000000000000000000 
ОООО00000000000000000000000000000000000 


32.2 []||MySQL 
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ОО00000000000000000 


ООДОМу ЗО С0Д0ОС0О0000000000000000 

ООДОО0О00000Му50200005.40000005.5000000000000000 
0005.5.хОО00000000000000000000000000000УМіпаоумз 
п5каегОООДОД00000000000009МІХИ ® чх 00000" mysqt 00 
ОООО00000000000000000000000000 


ОООО0000000000000 
http://dev.mysql.com/doc/refman/5.5/en/upgrading. html ПП 


ООДОД0О00000МУЗОСООО00О000О000000000000000000 
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й myisamchk -r -q --set-collation-new_coilation name 


32.3 |П Apache 


LIMySQLDODUDUDUD HA pach eni bip m p i i i Windo wsr] 
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ІтѕёаПеғО0000000000000000000000000000000000тоа ss 
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ОДУ МИХ їпих ДООДОДОДОДОДОб0Д000000000000000000000 


ООООО0000000000000000000102.2.1700000002.4.1200000000 
[IHE] httpd-2.2.17[]httpd-2.4.1[] 


АрасһеПП10000000000000соппоигер000000000000000 


# ./configure --prefix-/usr/local/apache2 


LEE ricenfigure[ inp A pa cher]min mn mmm mm II dm Apacher T] 
[Imake[]make install |[ |[ 


О0000000000Арасһер00000Арасһеро0000000001һра 
ООООО0000000000000000000000000000000000000000000000 
ОДОО0О00000000000У/еборооодородро0бо0оо0оо0оор000000000000 
ООООО00000000РЕСра. соп'ДОДОДОДОВОСОЗОДОДОДОДОДООО0000 
ОО000000000 


[]JUNIX/Linux[]L LTDA растепооооооооОРНРЦЦОМЛ т Ам ПП 
ООООО000000000000000000ОРНРОДООДООДОООРЕра сопт [III II] 
ПОООРНАРООООЦОООООО 


ОДАрасиерродод 


ОДОДООДАраспердрорордододророоророророорододроророод 
ОДО0000000000Ореп55 00000000 


ПОООООООМХ/ іпихООДОДОДООДО000ПРЕра-2.2.17000000 
00 таке clean 000000000Оплакебтеб ПП Dni Di pacher T] 
б0000000000000таке cleanQQ0000000000configureQQ00000 
ПтакеПтаке іпѕёаПО000000000000000000РНРО00 


П00ћра.соп#О0000000000000000000000000000 
Млпаом5 00000000000 


32.4 РНР 


ОДУ NIX/Linux ООДОДО0ОО0О00000000000ОРНРОООДОДОРНР 
ОООАраспеДМуз ОРОООДООООДООООДО00О000000000000000000 
ОООООДО0000000000000000000000000000Осо0пЛдигебпаке | 
make install[]make install[][][[PHP[]EEETELA pa ch eLTETETEIEIETETETETETETEI 
ОО000000000000АраспеПо000РНРОО00000 


ПППИППРНРЦППИПИИПИИИППИППИППИИПИПИПИПИПППИППИП 
О000000000000сопћоигеђтакеђтаке install IILI IILI I ilL 
РАРОООООДО00000000 


\МАпаом/ ППИПИИИИНИНИВОНОИНОВОВОООВООВОВООрир. и"! 
О000000000000Арасһероо0000000000000000000000000000 


ООО0ОО0000000000000000000000000000000000000000000000 
0000рһр.тО00000000000000000000Арасһерћіра.соп 000 
ПОРАРООООООООООООООООООРАРООООООООО 


ППРЕСІПРЕАВПОРНР 


ПППРЕСЦІРНР Extension community ПйргагуПРНРОДОДООО 
[]http://pecl.php. net/ ППРЕАВПРНР Extension and application 
геро5іїогуПРНРОДОДОДОДОР'Ер-// pear. php.net/ ВП000000000 
ОООО0О00000000000000000000000000000000000Ц 


ООООООРНРОДОДООООООПРЕСЄЕООДООДООДОО0ОООО00000000000 
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° ПООООО0ОО0000000000 
• ПОДОД000-00-0000000000000 
° ПООООДООООРИРОДОДООО 


ОДОО000000УУерооододО0б00000000000000000000000 
ОДООД0О0000000000000000000000000000У/еБордоор0000000 
ООО0О0000000000000000000000000000000000000000000000 
ООО00000000000000000000000000 
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ОДООО0О0000000000000000000000000000000000У/еб 000 
ООО0О0000000000000000000000000000000000000000000000 
ООООО00000000000000000000000000000007 О00000000000000 
ОООО00000000000000000000000000000000000000000"7 


ОООО0000000000000000000000000000000000000000000 
ОДОРНРООООООДОО0О0О0000-00-0000МУЄДООООООО0О000000000 
ООООО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 


ОДО00000УУеродододоорододродрорбобододрорбороро000000 
ОООО ОООО ОООО ООО ОООО 


ПОСООООСОООСОООООООООоООООООООО0ОО0О0ОМогаргеѕѕ 
(http://www.wordpress.org )[]Drupal (http://www.drupal.org ) 


[Joomla (http://www.joomla.org УДДОДОДО0О0000000000000 
ООО0О0000000000000000000000000000000000 


33.2 (ІІММСГТ 


ОООО0000000000000000000000000000000000000000000 
ОООО0000000000000000000000000000000000000000000000 
ООО0ОО0000000000000000000000000000000000000000000000 
ООООО0000000000000000000000000000000000000000000000 
ООО0О0000000000000000000 


МУСПОДОО0О0000УУебОДООООООДОООООООО00О0000000000000 
ОООО000000000000000000000003 3-100000000000МУСЄ0О000 
ООООО0000000000000000000000000000000000000000 
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033-1 мУсДоророб 
ПШПМУСЦППШПШПШПЗШИШИШИШШ 


e 00 -- --СО0О000000000000000000000000000000000000 
ООО0000000000000000000000000 

e UU ----ОООО000000000000000000000000000000000000 
ОО00000000000 

• 000 ----ООДООО00000000000000000000007007 00000000 
ООО00000000000000 


ООООО000000000МУМСЄ ОООО0О00000000000000000000000 
ООО00000000000000 


100000000000000000000 

2 В00000000000000000000 
ЗОДПОООД0000000000000000000000000000000000000000 
А ОО000000000000000000000 


ООООО0000РНРООООООООДО0ОМУМСЄДРОДОДООООО0000000000 
РАРОООООООДДО0О0О0ОО000000000000000000000000000000000 
0000000 


ПППППМУСПППИПИПИПИППИГПЦЕт Atwoodil|[|[ [| 
[“Understanding Моае!-Мем-Соп го ег" ГП 


http://www.codinghorror.com/ blog/2008/05/understanding- 
model- view-controller.html [] 


33.3 ПІПОРНРОДОДОГ 


ОООО000000000000000ЗО000ОРНАРООООДОООООО0О0000000 
ООООО000000000000000000000000000000000000000000000 
ООООО00000000000000000000ЗО00000000000000000000000 
ООО0О00000000000000000000000000000000000 


ОООО0000000000000000000000 


• ПОДООООДО0О0О0О0000000000000000000000000000000000 
ОО00000000000 

• ПОООООООО0О000000000000000000000000000000000000 

° ПООООДООООООРНРОДОСОООООООООООООО0О000000000000000 
ООО00000000000000000000 


ООООООДО0О0ЗОДО0000ОРНР0000000/епабСакернеРр 
СодеідпігегОД00000000000030000005уплїопу 
(http://www.symfony.com/ )[]Yii(http:// 
www.yiiframework.com!/ ДІ 00007 LILILILIWIKI pedia[]L]L] PHP 
ОООО00000000000000 
http://en.wikipedia.org/wiki/Comparison of web application 
frameworksZ PHP р 


33.3.1 Zend Framework 


ООООООДО000ОРНРО00000000000000О/епа Ргатемогкі Д 
(http://framework.zend.com/ )00000004епа00004епа 
ЕгаглеммогкО00000000РНРОООООООООООООООООООООООООРНРЦ 
ПО0002епароо00000000000000000000004епа Framework] 
ООДОбО000000000000000000000000000000 


0000000000/епа РгаппемгогкДОПО0ООД00000000000000 
ОООО0000000000000000000000000000000000000000000000 
000000 епапрооодоорророброброрордоровороороророводророоро 
Учеб ПОДООДОДОО00000000000 


ООООО0000000000000000000000000000000000000000000 
ООО0О0000000000000000000000000000000000000000000000 
ОООООД00000000000000000000000000000000000000 


ОО000000000000000000000000000000000000/епа 
Ргаглем/огкОООООООРНРЦАраскпедмузо LOUUUUUUUUOUNttp :// 
framework.zend.com/manual/en/requirements.introduction. 
html Requirements ПДООДООДОРНРБООООДООООДОО0О00000000 
[]http://framework.zend. com/ download/latest 0000000000 
ОООО0000000000000000000000000000000000000000000000 
0000000000000000000000000/епа Framework ООДО0О00 


http://framework.zend.com/ manual 
/en/learning.quickstart.intro.html 000000000000000000000 
ОДО000000000 


33.3.2 CakePHP 


ООООО0000000ОРНРОДОДОДО 
CakePHP(http://www.cakephp.org/ )00000000000000000000 
ПОСакеРНРОДОМУМСООООДОООДООО0ОООДО0О00000УУЄБО00000 
ППППППИПИПИПеепа Ргатемогку00000000000000000000 


СакеРнРрП00000000000000000000000000000000000000 
П0000042епа РгатеммогкО00000000000000000000000000000 
О0000000000000СакернРрпоо0000000000000000000000000 
ООО00000000000000 


ОО СакерРнРОДООООРНРОАраспермуьо 00000 
CakePHP Cookbook 
[]http://book.cakephp.org/2.0/en/installation.html [ ООООООО 
РАНРОООДООДООО0ОО000000000000000000000000000000000 


ОООООДО000000000000000УУеБодббОдодроородрборододо 
ОСакерРНРЮДООООДОО0ОД00000000000Со0р0кбоокОбОДОООО 
http://book.cakephp.org/2.0/en/getting-started.htm!l 000000 
0000000СакерРнеРООДОДОО0О00000000 


33.3.3 Codelgniter 


ПОСакеРнРООООООЦ 
Codelgniter(http://www.codeigniter.com )0000000000000000 
ОО0О0000000000000000000000000000000000000000000000о 
ОООООДО0000000000000000000000000С04еїдпісег ПЕЕ\еь п 


ООООО000000000000000000000000000000000000000000000 
ПП 


Codelgniter[ | ППМУСПИПИПИППИПИПИППППИПИППППППИПИПП 
О000000000000%еюопооо0000000000000000000000000000000 
ОДОД0О0000000000000000000000000000Сакеренеоор 
СоаеїдпікегоОДОДООПДОО000ДО00О00О0000000000000000000000 
ПП 


ПЦППСоае!дптеЦПЦППШППРНРПАрасһеП|Му5О 000000000 
http:// 
codeigniter.com/user guide/general/requirements.html [| 


server Кедштетеп 5 ООООООРНРОООООООО0О0О0О0О0ОООООО0ООО 
http://codeigniter.com/downloads/ ПОПОООВОООООО 


33.4 ПП 
ОООДООДО0000000000000000000000-00-0000000000000000 


ПОО00000000000000000000000030000РНРО0000002епар 
CakePHP[]Codelgniter] | 
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